![]() |
|
sfPropelActAsCommentableBehaviorPlugin - 0.3.0Propel commentable behavior |
|
![]() |
34
users
Sign-in
to change your status |
This behavior permits to attach comments to Propel objects. It provides a module for enabling comments in your application in less than 3 minutes. |
| Name | Status | |
|---|---|---|
|
|
lead | gro.tocal <<ta>> reivax |
Copyright (c) 2007 Xavier Lacot
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
| Version | License | API | Released |
|---|---|---|---|
| 1.2.0stable | MIT | 1.2.0stable | 16/01/2009 |
| Version | License | API | Released |
|---|---|---|---|
| 0.5.0beta | MIT | 0.5.0beta | 11/08/2008 |
| 0.4.0beta | MIT license | 0.4.0beta | 10/12/2007 |
| 0.3.0beta | MIT license | 0.3.0beta | 08/10/2007 |
| 0.2.0beta | MIT license | 0.2.0beta | 26/09/2007 |
| 0.1.0beta | MIT license | 0.1.0beta | 13/09/2007 |
sfPropelActAsCommentableStripper classsf_comment_$id
(Nicolas Perriault)Initial public release. Features comments attachment to heterogene Propel objects.
This behavior permits to attach comments to Propel objects. It provides a module for enabling comments in your application in less than 3 minutes.

go to your project's root
Install the plugin:
./symfony plugin-install http://plugins.symfony-project.com/sfPropelActAsCommentableBehaviorPlugin
if not already done, enabled behaviors in config/propel.ini:
propel.builder.addBehaviors = true
edit the classes that you want to make taggable. For instance, for lib/model/Post.php:
[php] getTitle(); ?>
getText(); ?>
<h3>Comments</h3>
<?php
include_component('sfComment', 'commentList', array('object' => $post));
include_component('sfComment', 'commentForm', array('object' => $post));
?>
By default, the comment list displays all the comments that do not belong to one namespace. If you want to display comments for the namespace "gerard", then simply pass this optionnal parameter to the component:
<?php include_component('sfComment', 'commentList', array('object' => $post, 'namespace' => 'gerard')); ?>
This also works for the comment-form component. This way, the following form will add the comment to the namespace "gerard":
<?php include_component('sfComment', 'commentList', array('object' => $post, 'namespace' => 'gerard')); ?>
You can protect namespaces from being accessed when the current user does not have some credentials ; have a look at the configuration file for further informations.
Consider a Propel "Post" class:
<?php class Post extends BasePost { } sfPropelBehavior::add('Post', array('sfPropelActAsCommentableBehavior'));
When the sfPropelActAsCommentableBehaviorPlugin is applied to the Post class, that class automagically gets commentable:
<?php $post = new Post(); // blah $post->save(); $post->addComment('This is a cool comment.'); $post->addComment(array('title' => 'this is a cool title', 'text' => 'this is a cool comment', 'author_id' => sfContext::getInstance()->getUser()->getUserId())); $post->addComment(array('This is a cool comment.', 'this is one other comment')); ### Retrieving one object's comments It is possible to retrieve comments from a commentable object: [php] <?php $post = PostPeer::retrieveByPk(1); $comments = $post->getComments(); foreach ($comments as $comment) { echo '<p>'.$comment->getText().'</p>'; } ### Removing one object's comment Of course, comments can also be removed: [php] <?php $post = PostPeer::retrieveByPk(1); $post->removeComment(12); $post->clearComments(); ## API The behavior implement the following methods: * **addComment($comment)** - Adds a comment to the object. The "comment" param can be an associative array (in which each element represents one of the comment properties), or an array of associative arrays. In this case, it adds all the comments to the object. * **clearComments()** - Deletes all the comments attached to the object * **getComments($options = array())** - Returns the list of the comments attached to the object. The options array can contain several options * **getNbComments()** - Returns the number of the comments attached to the object. * **removeComment($comment_id)** - Removes one comment from the object. ## Unit testing The plugin has been deeply unit-tested. The tests are located in test/unit/sfPropelActAsCommentableBehaviorTest.php. If you want to run them: * install the plugin * configure a model for using it, for instance "Post" * edit this file and, if required, modify the application name and the TEST_CLASS constant, line 3: define('TEST_CLASS', 'Post'); * run the tests: php plugins/sfPropelActAsCommentableBehaviorPlugin/test/unit/sfPropelActAsCommentableBehaviorTest.php ## In-depth usage tutorial This part is a complete tutorial for using the plugin both in front and back-office. ### Install the plugin * go to your project's root * Install the plugin: ./symfony plugin-install http://plugins.symfony-project.com/sfPropelActAsCommentableBehaviorPlugin * if not already done, enabled behaviors in config/propel.ini: propel.builder.addBehaviors = true * edit the classes that you want to make taggable. For instance, for lib/model/Post.php: [php] <?php class Post extends BasePost { } sfPropelBehavior::add('Post', array('sfPropelActAsCommentableBehavior')); * rebuild the model: ./symfony propel-build-all * clear the cache: ./symfony cc ### Set up the plugin * activate the "sfComment" module in the settings.yml of the frontend application: enabled_modules: [sfComment](default,) * activate both the "sfComment" and the "sfCommentAdmin" modules in the settings.yml of the backend application: enabled_modules: [sfComment, sfCommentAdmin](default,) * add the following lines in the app.yml of both **applications**: all: sfPropelActAsCommentableBehaviorPlugin: use_ajax: true anonymous: enabled: true layout: name: required email: required title: optional comment: required name: Anonymous User user: enabled: true layout: title: optional comment: required table: sf_guard_user id: id class: sfGuardUser id_method: getId toString: __toString namespaces: backend: administrator * tweak these values accordingly to the [previously explained settings](#Optionalsettings). Please note that only administrator can add comments in the comments "backend" namespace. ### Add comments in front-office Include the sfComment components where the comments and the commentform should appear: [php] <h2><?php echo $post->getTitle(); ?></h2>
getText(); ?>
<h3>Comments</h3>
<?php
include_component('sfComment', 'commentList', array('object' => $post, 'namespace' => 'frontend'));
include_component('sfComment', 'commentForm', array('object' => $post, 'namespace' => 'frontend'));
?>
The use of a "namespace" is not required in this case; but it is advised, as it makes it easier to find the comments back.
Include the sfComment components where the comments and the commentform shoumd appear:
<?php include_component('sfComment', 'commentList', array('object' => $post, 'namespace' => 'backend')); include_component('sfComment', 'commentForm', array('object' => $post, 'namespace' => 'backend')); ?>
This plugin is licensed under the MIT license. You can contact the maintainer at xavier@lacot.org
Initial public release. Features comments attachment to heterogene Propel objects.
