Commit a7113c99 authored by Armando Lüscher's avatar Armando Lüscher Committed by GitHub

Merge pull request #273 from noplanman/improve_inline_keyboard_button

Improve inline keyboard button
parents 632a4d08 bb8699ef
...@@ -14,32 +14,38 @@ use Longman\TelegramBot\Exception\TelegramException; ...@@ -14,32 +14,38 @@ use Longman\TelegramBot\Exception\TelegramException;
class InlineKeyboardButton extends Entity class InlineKeyboardButton extends Entity
{ {
/**#@+
* @var string
*/
protected $text; protected $text;
protected $url; protected $url;
protected $callback_data; protected $callback_data;
protected $switch_inline_query; protected $switch_inline_query;
/**#@-*/
/** /**
* InlineKeyboardButton constructor. * InlineKeyboardButton constructor.
* *
* @todo check if only one of 'url, callback_data, switch_inline_query' fields is set, documentation states that only one of these can be used
*
* @param array $data * @param array $data
*
* @throws \Longman\TelegramBot\Exception\TelegramException
*/ */
public function __construct($data = array()) public function __construct(array $data = [])
{ {
$this->text = isset($data['text']) ? $data['text'] : null; $this->text = isset($data['text']) ? $data['text'] : null;
if (empty($this->text)) { if (empty($this->text)) {
throw new TelegramException('text is empty!'); throw new TelegramException('text is empty!');
} }
$this->url = isset($data['url']) ? $data['url'] : null; $num_params = 0;
$this->callback_data = isset($data['callback_data']) ? $data['callback_data'] : null; foreach (['url', 'callback_data', 'switch_inline_query'] as $param) {
$this->switch_inline_query = isset($data['switch_inline_query']) ? $data['switch_inline_query'] : null; if (!empty($data[$param])) {
$this->$param = $data[$param];
if ($this->url === '' && $this->callback_data === '' && $this->switch_inline_query === '') { $num_params++;
throw new TelegramException('You must use at least one of these fields: url, callback_data, switch_inline_query!'); }
}
if ($num_params !== 1) {
throw new TelegramException('You must use only one of these fields: url, callback_data, switch_inline_query!');
} }
} }
} }
<?php
/**
* This file is part of the TelegramBot package.
*
* (c) Avtandil Kikabidze aka LONGMAN <akalongman@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Tests\Unit;
use Longman\TelegramBot\Entities\InlineKeyboardButton;
use Longman\TelegramBot\Exception\TelegramException;
/**
* @package TelegramTest
* @author Avtandil Kikabidze <akalongman@gmail.com>
* @copyright Avtandil Kikabidze <akalongman@gmail.com>
* @license http://opensource.org/licenses/mit-license.php The MIT License (MIT)
* @link http://www.github.com/akalongman/php-telegram-bot
*/
class InlineKeyboardButtonTest extends TestCase
{
/**
* @expectedException \Longman\TelegramBot\Exception\TelegramException
* @expectedExceptionMessage text is empty!
*/
public function testInlineKeyboardButtonNoTextFail()
{
new InlineKeyboardButton([]);
}
/**
* @expectedException \Longman\TelegramBot\Exception\TelegramException
* @expectedExceptionMessage You must use only one of these fields: url, callback_data, switch_inline_query!
*/
public function testInlineKeyboardButtonNoParameterFail()
{
new InlineKeyboardButton(['text' => 'message']);
}
/**
* @expectedException \Longman\TelegramBot\Exception\TelegramException
* @expectedExceptionMessage You must use only one of these fields: url, callback_data, switch_inline_query!
*/
public function testInlineKeyboardButtonTooManyParametersFail()
{
new InlineKeyboardButton(['text' => 'message', 'url' => 'url_value', 'callback_data' => 'callback_data_value']);
}
public function testInlineKeyboardButtonSuccess()
{
new InlineKeyboardButton(['text' => 'message', 'url' => 'url_value']);
new InlineKeyboardButton(['text' => 'message', 'callback_data' => 'callback_data_value']);
new InlineKeyboardButton(['text' => 'message', 'switch_inline_query' => 'switch_inline_query_value']);
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment