. * * @author Daniil Gentili * @copyright 2016-2023 Daniil Gentili * @license https://opensource.org/licenses/AGPL-3.0 AGPLv3 * @link https://docs.madelineproto.xyz MadelineProto documentation */ 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> */ public readonly array $buttons ) { } public static function fromRawReplyMarkup(array $rawReplyMarkup): ?self { return match ($rawReplyMarkup['_']) { 'replyKeyboardMarkup' => new ReplyKeyboard(array_column($rawReplyMarkup['rows'], 'buttons')), 'replyInlineMarkup' => new InlineKeyboard(array_column($rawReplyMarkup['rows'], 'buttons')), default => null }; } /** * Press button at the specified keyboard coordinates. * * @param bool $waitForResult If true, waits for a result from the bot before returning. */ public function pressByCoordinates(int $row, int $column, bool $waitForResult): mixed { return $this->buttons[$row][$column]->click(!$waitForResult); } /** * Presses the first keyboard button with the specified label. * * @param bool $waitForResult If true, waits for a result from the bot before returning. * * @throws AssertionError If a button with the specified label cannot be found. */ public function press(string $label, bool $waitForResult): mixed { 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!"); } }