mirror of
https://github.com/Mibew/advanced-button-plugin.git
synced 2024-11-15 00:34:14 +03:00
101 lines
3.1 KiB
PHP
101 lines
3.1 KiB
PHP
<?php
|
|
/*
|
|
* Copyright 2018, 2021 the original author or authors.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
namespace Mibew\Mibew\Plugin\AdvancedButton;
|
|
|
|
use Mibew\Asset\Generator\UrlGeneratorInterface as AssetUrlGeneratorInterface;
|
|
use Mibew\EventDispatcher\EventDispatcher;
|
|
|
|
/**
|
|
* Provides an ability to automatically refresh the button and set its
|
|
* visibility depending on chat state.
|
|
*/
|
|
class Plugin extends \Mibew\Plugin\AbstractPlugin implements \Mibew\Plugin\PluginInterface
|
|
{
|
|
protected $initialized = true;
|
|
|
|
// Default operational mode is visibility cloaking
|
|
protected $mode = 'visibility';
|
|
|
|
// Default submode for display cloaking mode
|
|
protected $submode = 'inline-block';
|
|
|
|
/**
|
|
* Class constructor.
|
|
*
|
|
* @param array $config List of the plugin config.
|
|
*
|
|
*/
|
|
public function __construct($config)
|
|
{
|
|
// Set operational mode
|
|
if (isset($config['mode'])) {
|
|
switch($config['mode']) {
|
|
case 'display':
|
|
$this->mode = 'display';
|
|
if (isset($config['submode'])) {
|
|
switch($config['submode']) {
|
|
case 'block':
|
|
$this->submode = 'block';
|
|
break;
|
|
case 'inline':
|
|
$this->submode = 'inline';
|
|
break;
|
|
}
|
|
}
|
|
break;
|
|
case 'none':
|
|
$this->mode = 'none';
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Defines necessary event listener.
|
|
*/
|
|
public function run()
|
|
{
|
|
$dispatcher = EventDispatcher::getInstance();
|
|
$dispatcher->attachListener('widgetResponseAlter', $this, 'refreshButton');
|
|
}
|
|
|
|
/**
|
|
* Returns verision of the plugin.
|
|
*
|
|
* @return string Plugin's version.
|
|
*/
|
|
public static function getVersion()
|
|
{
|
|
return '0.1.0';
|
|
}
|
|
|
|
/**
|
|
* Manage the button outlook.
|
|
*
|
|
* @param array $args Event data
|
|
*/
|
|
public function refreshButton(&$args)
|
|
{
|
|
$g = $args['asset_url_generator'];
|
|
$args['response']['load']['refresh'] = $g->generate(str_replace(DIRECTORY_SEPARATOR, '/', $this->getFilesPath()) . '/js/refresh.js', AssetUrlGeneratorInterface::ABSOLUTE_URL);
|
|
$args['response']['handlers'][] = 'refreshButton';
|
|
$args['response']['dependencies']['refreshButton'] = array('refresh');
|
|
$args['response']['data']['refreshButton'] = array('mode' => $this->mode, 'submode' => $this->submode);
|
|
}
|
|
}
|