-
Notifications
You must be signed in to change notification settings - Fork 32
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
10 changed files
with
273 additions
and
342 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,28 +1,76 @@ | ||
# Sending Messages | ||
|
||
There are many different types of message that a bot can send. | ||
Fortunately, methods for sending such messages are similar. Take a look at these examples: | ||
[data:image/s3,"s3://crabby-images/9408f/9408ff7179168fda76da7e3728675ecc8253605b" alt="send message method"](https://core.telegram.org/bots/api#sendmessage) | ||
[data:image/s3,"s3://crabby-images/6a9f8/6a9f89bec242ab8eb29967eca65ea0cb8d3c7337" alt="tests"](https://github.com/TelegramBots/Telegram.Bot/blob/master/test/Telegram.Bot.Tests.Integ/Sending%20Messages/TextMessageTests.cs) | ||
|
||
## Sending text message | ||
There are many different types of message that a bot can send, but let's start with text messages. | ||
|
||
data:image/s3,"s3://crabby-images/72631/726314c8a47e9327d63ac0ac04399dfdc3529fbd" alt="text message screenshot" | ||
## Basic text message | ||
|
||
```c# | ||
{{#include ../../../Examples/2/SendMessage.cs:text-message}} | ||
```csharp | ||
await bot.SendMessage(chatId, "Hello, World!"); | ||
``` | ||
data:image/s3,"s3://crabby-images/72631/726314c8a47e9327d63ac0ac04399dfdc3529fbd" alt="text message screenshot" | ||
|
||
The `chatId` parameter would typically be the ID of a chat or a user that you obtained on a [received message](../../3/updates/README.md), | ||
or it can be the @username of a public group/channel. | ||
|
||
## Advanced text message | ||
|
||
## Sending sticker message | ||
You can send messages with more characteristics: | ||
- text effects _(using HTML, Markdown, or text entities)_ | ||
- attached inline buttons | ||
- as a reply to a message | ||
- and more... | ||
|
||
data:image/s3,"s3://crabby-images/b929f/b929f5b00dd0e0369fb5f5a9dd3523c626a1ce2c" alt="sticker message screenshot" | ||
> [!IMPORTANT] | ||
> We highly recommend you use HTML instead of Markdown because Markdown has lots of annoying aspects | ||
```c# | ||
{{#include ../../../Examples/2/SendMessage.cs:sticker-message}} | ||
The code snippet below sends a message using various parameters: | ||
|
||
```csharp | ||
var message = await bot.SendMessage(chatId, "Trying <b>all the parameters</b> of <code>sendMessage</code> method", | ||
ParseMode.Html, | ||
protectContent: true, | ||
replyParameters: update.Message.Id, | ||
replyMarkup: new InlineKeyboardMarkup( | ||
InlineKeyboardButton.WithUrl("Check sendMessage method", "https://core.telegram.org/bots/api#sendmessage"))); | ||
``` | ||
data:image/s3,"s3://crabby-images/217be/217be973ca987f734e506a4e811c15e83a124140" alt="text message screenshot" | ||
|
||
Here `text` is written in [HTML format](https://core.telegram.org/bots/api#html-style) and `parseMode` indicates that. | ||
|
||
By passing `protectContent` we prevent the message (and eventual media) to be copiable/forwardable elsewhere. | ||
|
||
## Sending video message | ||
It's a good idea to make it clear to a user the reason why the bot is sending this message and that's why we pass the user's | ||
message id for `replyParameters`. | ||
|
||
data:image/s3,"s3://crabby-images/ab21b/ab21b5ba6afb040b882ad5f7f8b84299d41af994" alt="video message screenshot" | ||
You have the option of specifying a `replyMarkup` when sending messages. | ||
Reply markups are explained in details later in this book. | ||
Here we used an _Inline Keyboard Markup_ with a button that attaches to the message itself. | ||
Clicking that opens [`sendMessage`](https://core.telegram.org/bots/api#sendmessage) method documentation in the browser. | ||
|
||
```c# | ||
{{#include ../../../Examples/2/SendMessage.cs:video-message}} | ||
## Observing the Message that just got sent | ||
|
||
Almost all of the methods for sending messages return you the message you just sent. Let's have a look at this object. Add this statement after the previous code. | ||
```csharp | ||
{{#include ../../../Examples/2/SendMessage.cs:message-contents}} | ||
``` | ||
|
||
Output should look similar to this: | ||
```text | ||
Awesome bot sent message 123 to chat 123456789 at 8/21/18 11:25:09 AM. It is a reply to message 122 and has 2 message entities. | ||
``` | ||
Try putting a breakpoint in the code to examine all the properties on a message objects you get. | ||
|
||
There are a few things to note: | ||
- `message.Date` is a timestamp in [UTC format](https://en.wikipedia.org/wiki/Coordinated_Universal_Time) (use `message.Date.ToLocalTime()` to convert to your local timezone). | ||
- `message.Text`: plain text without effects | ||
- `message.Entities`: list of [text effects](https://core.telegram.org/bots/api#messageentity) to be apply to the plain text | ||
- `message.EntityValues`: text parts covered by these entities | ||
|
||
You can use our extension methods `message.ToHtml()` or `message.ToMarkdown()` to convert the text & entities back into HTML **(recommended)** or Markdown. | ||
|
||
## More message types | ||
|
||
Discover more message types in the [next pages](media-msg.md). |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.