2023-07-01 17:53:29 +02:00
|
|
|
<?php declare(strict_types=1);
|
|
|
|
|
2023-08-13 11:40:35 +02:00
|
|
|
/**
|
|
|
|
* This file is part of MadelineProto.
|
|
|
|
* MadelineProto is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
|
|
|
* MadelineProto is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
* See the GNU Affero General Public License for more details.
|
|
|
|
* You should have received a copy of the GNU General Public License along with MadelineProto.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* @author Daniil Gentili <daniil@daniil.it>
|
|
|
|
* @copyright 2016-2023 Daniil Gentili <daniil@daniil.it>
|
|
|
|
* @license https://opensource.org/licenses/AGPL-3.0 AGPLv3
|
|
|
|
* @link https://docs.madelineproto.xyz MadelineProto documentation
|
|
|
|
*/
|
|
|
|
|
2023-07-01 17:53:29 +02:00
|
|
|
namespace danog\MadelineProto\EventHandler;
|
|
|
|
|
|
|
|
use AssertionError;
|
|
|
|
use danog\MadelineProto\EventHandler\Keyboard\InlineKeyboard;
|
|
|
|
use danog\MadelineProto\EventHandler\Keyboard\ReplyKeyboard;
|
|
|
|
use danog\MadelineProto\TL\Types\Button;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents an inline or reply keyboard.
|
|
|
|
*/
|
|
|
|
abstract class Keyboard
|
|
|
|
{
|
|
|
|
/** @internal */
|
|
|
|
protected function __construct(
|
|
|
|
/** @var non-empty-list<non-empty-list<Button>> */
|
|
|
|
public readonly array $buttons
|
2023-07-01 18:04:20 +02:00
|
|
|
) {
|
2023-07-01 17:53:29 +02:00
|
|
|
}
|
|
|
|
|
2023-07-01 18:04:20 +02:00
|
|
|
public static function fromRawReplyMarkup(array $rawReplyMarkup): ?self
|
|
|
|
{
|
2023-07-01 17:53:29 +02:00
|
|
|
return match ($rawReplyMarkup['_']) {
|
2023-07-01 18:04:20 +02:00
|
|
|
'replyKeyboardMarkup' => new ReplyKeyboard(\array_column($rawReplyMarkup['rows'], 'buttons')),
|
|
|
|
'replyInlineMarkup' => new InlineKeyboard(\array_column($rawReplyMarkup['rows'], 'buttons')),
|
2023-07-01 17:53:29 +02:00
|
|
|
default => null
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2023-07-01 18:04:20 +02:00
|
|
|
/**
|
2023-07-01 17:53:29 +02:00
|
|
|
* Press button at the specified keyboard coordinates.
|
2023-07-01 18:04:20 +02:00
|
|
|
*
|
2023-07-01 17:53:29 +02:00
|
|
|
* @param bool $waitForResult If true, waits for a result from the bot before returning.
|
|
|
|
*/
|
2023-07-01 18:04:20 +02:00
|
|
|
public function pressByCoordinates(int $row, int $column, bool $waitForResult): mixed
|
|
|
|
{
|
2023-07-01 17:53:29 +02:00
|
|
|
return $this->buttons[$row][$column]->click(!$waitForResult);
|
|
|
|
}
|
|
|
|
|
2023-07-01 18:04:20 +02:00
|
|
|
/**
|
2023-07-01 17:53:29 +02:00
|
|
|
* Presses the first keyboard button with the specified label.
|
2023-07-01 18:04:20 +02:00
|
|
|
*
|
2023-07-01 17:53:29 +02:00
|
|
|
* @param bool $waitForResult If true, waits for a result from the bot before returning.
|
2023-07-01 18:04:20 +02:00
|
|
|
*
|
2023-07-01 17:53:29 +02:00
|
|
|
* @throws AssertionError If a button with the specified label cannot be found.
|
|
|
|
*/
|
2023-07-01 18:04:20 +02:00
|
|
|
public function press(string $label, bool $waitForResult): mixed
|
|
|
|
{
|
2023-07-01 17:53:29 +02:00
|
|
|
foreach ($this->buttons as $rows) {
|
|
|
|
foreach ($rows as $button) {
|
|
|
|
if ($button->label === $label) {
|
|
|
|
return $button->click(!$waitForResult);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
throw new AssertionError("Could not find a button with the specified label!");
|
|
|
|
}
|
2023-07-01 18:04:20 +02:00
|
|
|
}
|