2023-02-14 15:31:10 -05:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/** @noinspection PhpMissingFieldTypeInspection */
|
|
|
|
|
|
|
|
namespace TgBotLib\Objects;
|
|
|
|
|
|
|
|
use TgBotLib\Interfaces\ObjectTypeInterface;
|
|
|
|
|
|
|
|
class LabeledPrice implements ObjectTypeInterface
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
private $label;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
private $amount;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Portion label
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getLabel(): string
|
|
|
|
{
|
|
|
|
return $this->label;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Price of the product in the smallest units of the currency (integer, not float/double). For example, for a
|
|
|
|
* price of US$ 1.45 pass amount = 145. See the exp parameter in currencies.json, it shows the number of digits
|
|
|
|
* past the decimal point for each currency (2 for the majority of currencies).
|
|
|
|
*
|
|
|
|
* @see https://core.telegram.org/bots/payments#supported-currencies
|
|
|
|
* @see https://core.telegram.org/bots/payments/currencies.json
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getAmount(): int
|
|
|
|
{
|
|
|
|
return $this->amount;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns an array representation of the object
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function toArray(): array
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'label' => $this->label,
|
|
|
|
'amount' => $this->amount,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructs the object from an array representation
|
|
|
|
*
|
|
|
|
* @param array $data
|
|
|
|
* @return ObjectTypeInterface
|
|
|
|
*/
|
|
|
|
public static function fromArray(array $data): ObjectTypeInterface
|
|
|
|
{
|
|
|
|
$object = new self();
|
|
|
|
|
2023-02-14 17:35:16 -05:00
|
|
|
$object->label = $data['label'] ?? null;
|
|
|
|
$object->amount = $data['amount'] ?? null;
|
2023-02-14 15:31:10 -05:00
|
|
|
|
|
|
|
return $object;
|
|
|
|
}
|
|
|
|
}
|