elitedivision/amos-comments

Comments for contents - plugin

1.11.1 2023-10-26 09:29 UTC

README

Extension for comment a content like news, events, etc...

Installation

1 The preferred way to install this extension is through composer.

Either run

composer require elitedivision/amos-comments

or add this row

"elitedivision/amos-comments": "dev-master"

to the require section of your composer.json file.

2 Add module to your main config in backend:

<?php
'modules' => [
    'comments' => [
        'class' => 'elitedivision\amos\comments\AmosComments',
        'modelsEnabled' => [
            /**
             * Add here the classnames of the models where you want the comments
             * (i.e. 'elitedivision\amos\events\models\Event')
             */
        ],
        // the following are mandatory fields
        'displayNotifyCheckbox' => true, // if the notify checkbox in the accordion must be shown (if hidden, the notify checkbox is selected)
        'accordionOpenedByDefault' => false, // if the accordion must be opened by default
    ],
],

Also, add these lines to your bootstrap:

<?php
'bootstrap' => [
    'comments',
],

3 Add the view component to your main config in common:

<?php
'components' => [
    'view' => [
        'class' => 'elitedivision\amos\core\components\AmosView',
    ],
],

4 Apply migrations

php yii migrate/up --migrationPath=@vendor/elitedivision/amos-comments/src/migrations

or add this row to your migrations config in console:

<?php
return [
    '@vendor/elitedivision/amos-comments/src/migrations',
];

5 Implement the CommentInterface in your model

<?php
use elitedivision\amos\comments\models\CommentInterface;

/**
 * Implement the CommentInterface
 */
class MyClass implements CommentInterface

/**
 * Add the required method that must return boolean
 */
public function isCommentable()
{
    return true;
}

6 Add your model to the modulesEnables in the module config in backend/config/main.php

<?php
'modules' => [
    'comments' => [
        'class' => 'elitedivision\amos\comments\AmosComments',
        'modelsEnabled' => [
            'class_namespace\MyClass'
        ]
    ],
],

7 disable mail notifications

<?php
'modules' => [
    'comments' => [
        'class' => 'elitedivision\amos\comments\AmosComments',
        'enableMailsNotification' => false,
        'modelsEnabled' => [
            'class_namespace\MyClass'
        ]
    ],
],

*htmlMailContent - string/array
change the content of the mail of notification when you insert a comment you can insert an array

  'comments' => [
       'htmlMailContent' => [
            'elitedivision\amos\news\models\News' => '@backend/mail/comment/content_news',
            'elitedivision\amos\discussioni\models\DiscussioniTopic' => '@backend/mail/comment/content_discussioni',
            'elitedivision\amos\documenti\models\Documenti' => '@backend/mail/comment/content_documenti'
        ],

or a string if the conente is valid for all contents(news/discussioni/docuemnts/ecc..)

  'comments' => [
    'htmlMailContent' => '@backend/mail/comment/content_news'
    ]

enableCommentOnlyWithScope *enableCommentOnlyWithScope - boolean default false
If true it enable the comments olny with the scope (in the community)

  'comments' => [
       'enableCommentOnlyWithScope' => true,
  ]