1
0
mirror of https://github.com/danog/MadelineProto.git synced 2025-01-11 22:48:16 +01:00
MadelineProto/src/EventHandler/Keyboard.php

60 lines
1.9 KiB
PHP
Raw Normal View History

2023-07-01 17:53:29 +02:00
<?php declare(strict_types=1);
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
}