mirror of
https://github.com/Mibew/title-notification-plugin.git
synced 2024-11-15 00:44:12 +03:00
170 lines
5.0 KiB
PHP
170 lines
5.0 KiB
PHP
<?php
|
|
/*
|
|
* This file is a part of Mibew Title Notification Plugin.
|
|
*
|
|
* Copyright 2014 Dmitriy Simushev <simushevds@gmail.com>.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
/**
|
|
* @file The main file of Mibew:TitleNotification plugin.
|
|
*/
|
|
|
|
namespace Mibew\Mibew\Plugin\TitleNotification;
|
|
|
|
use Mibew\EventDispatcher\EventDispatcher;
|
|
use Mibew\EventDispatcher\Events;
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
|
|
/**
|
|
* The main plugin's file definition.
|
|
*
|
|
* It only attaches needed CSS and JS files to chat windows.
|
|
*/
|
|
class Plugin extends \Mibew\Plugin\AbstractPlugin implements \Mibew\Plugin\PluginInterface
|
|
{
|
|
/**
|
|
* List of the plugin configs.
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $config;
|
|
|
|
/**
|
|
* Indicates if the plugin was initialized correctly.
|
|
*
|
|
* @var boolean
|
|
*/
|
|
protected $initialized = false;
|
|
|
|
/**
|
|
* Class constructor.
|
|
*
|
|
* @param array $config List of the plugin config. The following options are
|
|
* supported:
|
|
* - "new_thread": boolean, if set to true window title of the visitors
|
|
* awaiting page will be changed when a visitor starts a new thread.
|
|
* The default value is true.
|
|
* - "new_message": string, indicates in what chat windows the title
|
|
* should be changed when a new message is came. The possible values
|
|
* are "client", "operator", "both", "none". The default value is "both".
|
|
*/
|
|
public function __construct($config)
|
|
{
|
|
$bad_config = isset($config['new_message'])
|
|
&& !in_array(
|
|
$config['new_message'],
|
|
array('client', 'operator', 'both', 'none')
|
|
);
|
|
|
|
if ($bad_config) {
|
|
// Config is invalid the plugin cannot be used. Nevertheless
|
|
// the system should work well without the plugin.
|
|
trigger_error(
|
|
'Wrong value of "new_message" configuration parameter',
|
|
E_USER_WARNING
|
|
);
|
|
|
|
return;
|
|
}
|
|
|
|
$this->initialized = true;
|
|
$this->config = $config + array(
|
|
'new_thread' => true,
|
|
'new_message' => 'both',
|
|
);
|
|
}
|
|
|
|
/**
|
|
* The main entry point of a plugin.
|
|
*/
|
|
public function run()
|
|
{
|
|
// Attach CSS and JS files of the plugin to chat window.
|
|
$dispatcher = EventDispatcher::getInstance();
|
|
$dispatcher->attachListener(Events::PAGE_ADD_JS, $this, 'attachJsFiles');
|
|
}
|
|
|
|
/**
|
|
* Event handler for "pageAddJS" event.
|
|
*
|
|
* @param array $args
|
|
*/
|
|
public function attachJSFiles(&$args)
|
|
{
|
|
$need_users_plugin = $this->needUsersPlugin($args['request']);
|
|
$need_chat_plugin = $this->needChatPlugin($args['request']);
|
|
|
|
if ($need_users_plugin || $need_chat_plugin) {
|
|
$base_path = str_replace(DIRECTORY_SEPARATOR, '/', $this->getFilesPath());
|
|
$args['js'][] = $base_path . '/vendor/jquery-titlealert/jquery.titlealert.js';
|
|
|
|
if ($need_users_plugin) {
|
|
$args['js'][] = $base_path . '/js/users_plugin.js';
|
|
} else {
|
|
$args['js'][] = $base_path . '/js/chat_plugin.js';
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Specify version of the plugin.
|
|
*
|
|
* @return string Plugin's version.
|
|
*/
|
|
public static function getVersion()
|
|
{
|
|
return '1.0.1';
|
|
}
|
|
|
|
/**
|
|
* Specify dependencies of the plugin.
|
|
*
|
|
* @return array List of dependencies
|
|
*/
|
|
public static function getDependencies()
|
|
{
|
|
// This plugin does not depend on others so return an empty array.
|
|
return array();
|
|
}
|
|
|
|
/**
|
|
* Checks if the JS part for users page should be attached.
|
|
*
|
|
* @param Request $request Incoming request
|
|
* @return boolean
|
|
*/
|
|
protected function needUsersPlugin(Request $request)
|
|
{
|
|
return $request->attributes->get('_route') == 'users' && $this->config['new_thread'];
|
|
}
|
|
|
|
/**
|
|
* Checks if the JS part for chat page should be attached.
|
|
*
|
|
* @param Request $request Incoming request
|
|
* @return boolean
|
|
*/
|
|
protected function needChatPlugin(Request $request)
|
|
{
|
|
$route = $request->attributes->get('_route');
|
|
$new_message = $this->config['new_message'];
|
|
$notify_operator = ($new_message == 'operator') || ($new_message == 'both');
|
|
$notify_client = ($new_message == 'client') || ($new_message == 'both');
|
|
|
|
return ($route == 'chat_operator' && $notify_operator)
|
|
|| (in_array($route, array('chat_user', 'chat_user_start')) && $notify_client);
|
|
}
|
|
}
|