diff --git a/data/core.telegram.org/method/stickers.createStickerSet b/data/core.telegram.org/method/stickers.createStickerSet new file mode 100644 index 0000000000..49dedfb447 --- /dev/null +++ b/data/core.telegram.org/method/stickers.createStickerSet @@ -0,0 +1,282 @@ +<!DOCTYPE html> +<html class=""> + <head> + <meta charset="utf-8"> + <title>stickers.createStickerSet</title> + <meta name="viewport" content="width=device-width, initial-scale=1.0"> + <meta property="description" content="Create a stickerset, bots only."> + <meta property="og:title" content="stickers.createStickerSet"> + <meta property="og:image" content=""> + <meta property="og:description" content="Create a stickerset, bots only."> + <link rel="shortcut icon" href="/favicon.ico?4" type="image/x-icon" /> + + <link href="/css/bootstrap.min.css?3" rel="stylesheet"> + + <link href="/css/telegram.css?215" rel="stylesheet" media="screen"> + <style> + </style> + </head> + <body class="preload"> + <div class="dev_page_wrap"> + <div class="dev_page_head navbar navbar-static-top navbar-tg"> + <div class="navbar-inner"> + <div class="container clearfix"> + <ul class="nav navbar-nav navbar-right hidden-xs"><li class="navbar-twitter"><a href="https://twitter.com/telegram" target="_blank" data-track="Follow/Twitter" onclick="trackDlClick(this, event)"><i class="icon icon-twitter"></i><span> Twitter</span></a></li></ul> + <ul class="nav navbar-nav"> + <li><a href="//telegram.org/">Home</a></li> +<li class="hidden-xs"><a href="//telegram.org/faq">FAQ</a></li> +<li class="hidden-xs"><a href="//telegram.org/apps">Apps</a></li> +<li class="active"><a href="/api">API</a></li> +<li class=""><a href="/mtproto">Protocol</a></li> +<li class=""><a href="/schema">Schema</a></li> + </ul> + </div> + </div> + </div> + <div class="container clearfix"> + <div class="dev_page"> + <div id="dev_page_content_wrap" class=" "> + <div class="dev_page_bread_crumbs"><ul class="breadcrumb clearfix"><li><a href="/api" >API</a></li><i class="icon icon-breadcrumb-divider"></i><li><a href="/methods" >All Methods</a></li><i class="icon icon-breadcrumb-divider"></i><li><a href="/method/stickers.createStickerSet" >stickers.createStickerSet</a></li></ul></div> + <h1 id="dev_page_title">stickers.createStickerSet</h1> + + <div id="dev_page_content"><p>Create a stickerset, bots only.</p> +<p><div class="clearfix"> + <ul class="dev_layer_select slightly-pull-right nav nav-pills"> + <li class="dropdown"> + <a class="dropdown-toggle" onclick="return dropdownClick(this, event)" href="#">Layer 133 <b class="caret"></b></a> + <ul class="dropdown-menu"> + <li><a href="?layer=1">1 – Base layer</a></li><li><a href="?layer=2">2 – New userpic notifications</a></li><li><a href="?layer=3">3 – Send message can trigger link change</a></li><li><a href="?layer=4">4 – Check-in chats</a></li><li><a href="?layer=5">5 – Localized SMS, localized notifications</a></li><li><a href="?layer=6">6 – Foursquare integration</a></li><li><a href="?layer=7">7 – Added wallPaperSolid</a></li><li><a href="?layer=8">8 – Added end-to-end encryption</a></li><li><a href="?layer=9">9 – Improved big files upload perfomance</a></li><li><a href="?layer=10">10 – Improved chat participants updates</a></li><li><a href="?layer=11">11 – Improved secret chats</a></li><li><a href="?layer=12">12 – New dynamic support</a></li><li><a href="?layer=13">13 – Audio, video MIME; contacts import retry; new secret actions</a></li><li><a href="?layer=14">14 – Notify settings sync, blacklist sync</a></li><li><a href="?layer=15">15 – Modified getHistory offset behaviour</a></li><li><a href="?layer=16">16 – Split sendCode into 2 parts</a></li><li><a href="?layer=17">17 – Added custom typing, introduced message flags</a></li><li><a href="?layer=18">18 – Added usernames</a></li><li><a href="?layer=23">23 – Stickers for secret chats</a></li><li><a href="?layer=105">105 – Scheduled messages, Cloud themes</a></li><li><a href="?layer=108">108 – Login with QR code</a></li><li><a href="?layer=109">109 – Polls v2</a></li><li><a href="?layer=110">110 – People Nearby 2.0, Bank card entity</a></li><li><a href="?layer=111">111 – Folders, Broadcast Stats</a></li><li><a href="?layer=112">112 – Old featured stickers, generic dice, poll timer, poll solution</a></li><li><a href="?layer=113">113 – PSA</a></li><li><a href="?layer=114">114 – Video thumbs for GIFs</a></li><li><a href="?layer=115">115 – Peek Channel Invite</a></li><li><a href="?layer=116">116 – Group Stats, Profile Videos</a></li><li><a href="?layer=117">117 – WebRTC Phone Calls</a></li><li><a href="?layer=118">118 – Callback with 2FA, Countries list</a></li><li><a href="?layer=119">119 – Comments in channels, Threads, Anonymous Admins</a></li><li><a href="?layer=120">120 – Multipins, Message Stats, GeoLive v2</a></li><li><a href="?layer=121">121 – SVG-based Outlines for Stickers</a></li><li><a href="?layer=122">122 – Voice Chats</a></li><li><a href="?layer=123">123 – Voice Chat improvements</a></li><li><a href="?layer=124">124 – Expiring Invite links</a></li><li><a href="?layer=125">125 – Voice Chats in Broadcasts</a></li><li><a href="?layer=126">126 – Ban channels in channels</a></li><li><a href="?layer=127">127 – Payments in channels</a></li><li><a href="?layer=128">128 – Microthumbs for User/Chat profile photos</a></li><li><a href="?layer=129">129 – Video Chats</a></li><li><a href="?layer=130">130 – Custom placeholder for bot reply keyboards</a></li><li><a href="?layer=131">131 – Reset 2FA Password after a week</a></li><li><a href="?layer=132">132 – Chat themes</a></li><li><a href="?layer=133"><strong>133 – 64-bit IDs for User/Chat</strong></a></li> + <li class="divider"></li> + <li><a href="/api/layers">More...</a></li> + </ul> + </li> + </ul> +</div> +<pre class="page_scheme"><code><a href="/constructor/messages.stickerSet" >messages.stickerSet</a>#b60a24a6 set:<a href="/type/StickerSet" >StickerSet</a> packs:<a href="/type/Vector%20t" >Vector</a><<a href="/type/StickerPack" >StickerPack</a>> documents:<a href="/type/Vector%20t" >Vector</a><<a href="/type/Document" >Document</a>> = <a href="/type/messages.StickerSet" >messages.StickerSet</a>; +---functions--- +<a href="/method/stickers.createStickerSet" class="current_page_link" >stickers.createStickerSet</a>#9021ab67 flags:<a href="/type/%23" >#</a> masks:flags.0?true animated:flags.1?true videos:flags.4?true user_id:<a href="/type/InputUser" >InputUser</a> title:<a href="/type/string" >string</a> short_name:<a href="/type/string" >string</a> thumb:flags.2?<a href="/type/InputDocument" >InputDocument</a> stickers:<a href="/type/Vector%20t" >Vector</a><<a href="/type/InputStickerSetItem" >InputStickerSetItem</a>> software:flags.3?<a href="/type/string" >string</a> = <a href="/type/messages.StickerSet" >messages.StickerSet</a>;</code></pre></p> +<h3><a class="anchor" href="#parameters" id="parameters" name="parameters"><i class="anchor-icon"></i></a>Parameters</h3> +<table class="table"> +<thead> +<tr> +<th>Name</th> +<th style="text-align: center;">Type</th> +<th>Description</th> +</tr> +</thead> +<tbody> +<tr> +<td><strong>flags</strong></td> +<td style="text-align: center;"><a href="/type/%23">#</a></td> +<td>Flags, see <a href="/mtproto/TL-combinators#conditional-fields">TL conditional fields</a></td> +</tr> +<tr> +<td><strong>masks</strong></td> +<td style="text-align: center;"><a href="/mtproto/TL-combinators#conditional-fields">flags</a>.0?<a href="/constructor/true">true</a></td> +<td>Whether this is a mask stickerset</td> +</tr> +<tr> +<td><strong>animated</strong></td> +<td style="text-align: center;"><a href="/mtproto/TL-combinators#conditional-fields">flags</a>.1?<a href="/constructor/true">true</a></td> +<td>Whether this is an animated stickerset</td> +</tr> +<tr> +<td><strong>user_id</strong></td> +<td style="text-align: center;"><a href="/type/InputUser">InputUser</a></td> +<td>Stickerset owner</td> +</tr> +<tr> +<td><strong>title</strong></td> +<td style="text-align: center;"><a href="/type/string">string</a></td> +<td>Stickerset name, <code>1-64</code> chars</td> +</tr> +<tr> +<td><strong>short_name</strong></td> +<td style="text-align: center;"><a href="/type/string">string</a></td> +<td>Sticker set name. Can contain only English letters, digits and underscores. Must end with <em>"</em>by<em><bot username="">"</bot></em> (<em><bot_username></bot_username></em> is case insensitive); 1-64 characters</td> +</tr> +<tr> +<td><strong>thumb</strong></td> +<td style="text-align: center;"><a href="/mtproto/TL-combinators#conditional-fields">flags</a>.2?<a href="/type/InputDocument">InputDocument</a></td> +<td>Thumbnail</td> +</tr> +<tr> +<td><strong>stickers</strong></td> +<td style="text-align: center;"><a href="/type/Vector%20t">Vector</a><<a href="/type/InputStickerSetItem">InputStickerSetItem</a>></td> +<td>Stickers</td> +</tr> +<tr> +<td><strong>software</strong></td> +<td style="text-align: center;"><a href="/mtproto/TL-combinators#conditional-fields">flags</a>.3?<a href="/type/string">string</a></td> +<td>Used when <a href="/import-stickers">importing stickers using the sticker import SDKs</a>, specifies the name of the software that created the stickers</td> +</tr> +</tbody> +</table> +<h3><a class="anchor" href="#result" id="result" name="result"><i class="anchor-icon"></i></a>Result</h3> +<p><a href="/type/messages.StickerSet">messages.StickerSet</a></p> +<h3><a class="anchor" href="#possible-errors" id="possible-errors" name="possible-errors"><i class="anchor-icon"></i></a>Possible errors</h3> +<table class="table"> +<thead> +<tr> +<th>Code</th> +<th>Type</th> +<th>Description</th> +</tr> +</thead> +<tbody> +<tr> +<td>400</td> +<td>BOT_MISSING</td> +<td>This method can only be run by a bot.</td> +</tr> +<tr> +<td>400</td> +<td>PACK_SHORT_NAME_INVALID</td> +<td>Short pack name invalid.</td> +</tr> +<tr> +<td>400</td> +<td>PACK_SHORT_NAME_OCCUPIED</td> +<td>A stickerpack with this name already exists.</td> +</tr> +<tr> +<td>400</td> +<td>PACK_TITLE_INVALID</td> +<td>The stickerpack title is invalid.</td> +</tr> +<tr> +<td>400</td> +<td>PEER_ID_INVALID</td> +<td>The provided peer id is invalid.</td> +</tr> +<tr> +<td>400</td> +<td>SHORTNAME_OCCUPY_FAILED</td> +<td>An internal error occurred.</td> +</tr> +<tr> +<td>400</td> +<td>STICKERS_EMPTY</td> +<td>No sticker provided.</td> +</tr> +<tr> +<td>400</td> +<td>STICKER_EMOJI_INVALID</td> +<td>Sticker emoji invalid.</td> +</tr> +<tr> +<td>400</td> +<td>STICKER_FILE_INVALID</td> +<td>Sticker file invalid.</td> +</tr> +<tr> +<td>400</td> +<td>STICKER_PNG_DIMENSIONS</td> +<td>Sticker png dimensions invalid.</td> +</tr> +<tr> +<td>400</td> +<td>STICKER_PNG_NOPNG</td> +<td>One of the specified stickers is not a valid PNG file.</td> +</tr> +<tr> +<td>400</td> +<td>STICKER_TGS_NODOC</td> +<td>Incorrect document type for sticker.</td> +</tr> +<tr> +<td>400</td> +<td>STICKER_TGS_NOTGS</td> +<td>Invalid TGS sticker provided.</td> +</tr> +<tr> +<td>400</td> +<td>STICKER_THUMB_PNG_NOPNG</td> +<td>Incorrect stickerset thumb file provided, PNG / WEBP expected.</td> +</tr> +<tr> +<td>400</td> +<td>STICKER_THUMB_TGS_NOTGS</td> +<td>Incorrect stickerset TGS thumb file provided.</td> +</tr> +<tr> +<td>400</td> +<td>USER_ID_INVALID</td> +<td>The provided user ID is invalid.</td> +</tr> +</tbody> +</table> +<h3><a class="anchor" href="#bots-can-use-this-method" id="bots-can-use-this-method" name="bots-can-use-this-method"><i class="anchor-icon"></i></a>Bots can use this method</h3></div> + +</div> + + </div> + </div> + <div class="footer_wrap"> + <div class="footer_columns_wrap footer_desktop"> + <div class="footer_column footer_column_telegram"> + <h5>Telegram</h5> + <div class="footer_telegram_description"></div> + Telegram is a cloud-based mobile and desktop messaging app with a focus on security and speed. + </div> + + <div class="footer_column"> + <h5><a href="//telegram.org/faq">About</a></h5> + <ul> + <li><a href="//telegram.org/faq">FAQ</a></li> + <li><a href="//telegram.org/blog">Blog</a></li> + <li><a href="//telegram.org/jobs">Jobs</a></li> + </ul> + </div> + <div class="footer_column"> + <h5><a href="//telegram.org/apps#mobile-apps">Mobile Apps</a></h5> + <ul> + <li><a href="//telegram.org/dl/ios">iPhone/iPad</a></li> + <li><a href="//telegram.org/dl/android">Android</a></li> + <li><a href="//telegram.org/dl/wp">Windows Phone</a></li> + </ul> + </div> + <div class="footer_column"> + <h5><a href="//telegram.org/apps#desktop-apps">Desktop Apps</a></h5> + <ul> + <li><a href="//desktop.telegram.org/">PC/Mac/Linux</a></li> + <li><a href="//macos.telegram.org/">macOS</a></li> + <li><a href="//telegram.org/dl/web">Web-browser</a></li> + </ul> + </div> + <div class="footer_column footer_column_platform"> + <h5><a href="/">Platform</a></h5> + <ul> + <li><a href="/api">API</a></li> + <li><a href="//translations.telegram.org/">Translations</a></li> + <li><a href="//instantview.telegram.org/">Instant View</a></li> + </ul> + </div> + </div> + <div class="footer_columns_wrap footer_mobile"> + <div class="footer_column"> + <h5><a href="//telegram.org/faq">About</a></h5> + </div> + <div class="footer_column"> + <h5><a href="//telegram.org/blog">Blog</a></h5> + </div> + <div class="footer_column"> + <h5><a href="//telegram.org/apps">Apps</a></h5> + </div> + <div class="footer_column"> + <h5><a href="/">Platform</a></h5> + </div> + <div class="footer_column"> + <h5><a href="https://twitter.com/telegram" target="_blank" data-track="Follow/Twitter" onclick="trackDlClick(this, event)">Twitter</a></h5> + </div> + </div> +</div> + </div> + <script src="/js/main.js?43"></script> + + <script>backToTopInit("Go up"); +removePreloadInit(); +</script> + </body> +</html> + diff --git a/data/corefork.telegram.org/api/animated-emojis.html b/data/corefork.telegram.org/api/animated-emojis.html new file mode 100644 index 0000000000..f4c1402574 --- /dev/null +++ b/data/corefork.telegram.org/api/animated-emojis.html @@ -0,0 +1,187 @@ +<!DOCTYPE html> +<html class=""> + <head> + <meta charset="utf-8"> + <title>Animated Emojis</title> + <meta name="viewport" content="width=device-width, initial-scale=1.0"> + <meta property="description" content="Graphical telegram clients should transform emojis into their respective animated version."> + <meta property="og:title" content="Animated Emojis"> + <meta property="og:image" content=""> + <meta property="og:description" content="Graphical telegram clients should transform emojis into their respective animated version."> + <link rel="shortcut icon" href="/favicon.ico?4" type="image/x-icon" /> + + <link href="/css/bootstrap.min.css?3" rel="stylesheet"> + + <link href="/css/telegram.css?215" rel="stylesheet" media="screen"> + <style> + </style> + </head> + <body class="preload"> + <div class="dev_page_wrap"> + <div class="dev_page_head navbar navbar-static-top navbar-tg"> + <div class="navbar-inner"> + <div class="container clearfix"> + <ul class="nav navbar-nav navbar-right hidden-xs"><li class="navbar-twitter"><a href="https://twitter.com/telegram" target="_blank" data-track="Follow/Twitter" onclick="trackDlClick(this, event)"><i class="icon icon-twitter"></i><span> Twitter</span></a></li></ul> + <ul class="nav navbar-nav"> + <li><a href="//telegram.org/">Home</a></li> +<li class="hidden-xs"><a href="//telegram.org/faq">FAQ</a></li> +<li class="hidden-xs"><a href="//telegram.org/apps">Apps</a></li> +<li class="active"><a href="/api">API</a></li> +<li class=""><a href="/mtproto">Protocol</a></li> +<li class=""><a href="/schema">Schema</a></li> + </ul> + </div> + </div> + </div> + <div class="container clearfix"> + <div class="dev_page"> + <div id="dev_page_content_wrap" class=" "> + <div class="dev_page_bread_crumbs"><ul class="breadcrumb clearfix"><li><a href="/api" >API</a></li><i class="icon icon-breadcrumb-divider"></i><li><a href="/api/animated-emojis" >Animated Emojis</a></li></ul></div> + <h1 id="dev_page_title">Animated Emojis</h1> + + <div id="dev_page_content"><p>Graphical telegram clients should transform emojis into their respective animated version. </p> +<pre><code><a href='/constructor/inputStickerSetAnimatedEmoji'>inputStickerSetAnimatedEmoji</a>#28703c8 = <a href='/type/InputStickerSet'>InputStickerSet</a>; + +<a href='/constructor/messages.stickerSet'>messages.stickerSet</a>#b60a24a6 set:<a href='/type/StickerSet'>StickerSet</a> packs:<a href='/type/Vector%20t'>Vector</a><<a href='/type/StickerPack'>StickerPack</a>> documents:<a href='/type/Vector%20t'>Vector</a><<a href='/type/Document'>Document</a>> = <a href='/type/messages.StickerSet'>messages.StickerSet</a>; + +---functions--- + +<a href='/method/messages.getStickerSet'>messages.getStickerSet</a>#2619a90e stickerset:<a href='/type/InputStickerSet'>InputStickerSet</a> = <a href='/type/messages.StickerSet'>messages.StickerSet</a>;</code></pre> +<p>On startup, clients should fetch the animated emoji stickerset by calling the <a href="/method/messages.getStickerSet">messages.getStickerSet</a> method, providing <a href="/constructor/inputStickerSetAnimatedEmoji">inputStickerSetAnimatedEmoji</a> to the <code>stickerset</code> field.<br> +The returned stickerset will contain a set of animated stickers, one for each of the supported emojis. </p> +<p>Clients should substitute messages containing only one instance of one of the allowed emojis with the respective animated sticker. </p> +<p>Animated emojis should loop only once when first sent or received, or when clicked.<br> +For <a href="#emoji-reactions">supported emojis</a>, clients on both sides of private chats with users are supposed to show a reaction animation when any of the two users clicks on the animated emoji: <a href="#emoji-reactions">click here for more info ยป</a>.</p> +<p>For special <a href="/api/dice">dice emojis</a> like <img class="emoji" src="//telegram.org/img/emoji/40/F09F8EB2.png" width="20" height="20" alt="๐ฒ" />, <img class="emoji" src="//telegram.org/img/emoji/40/F09F8EAF.png" width="20" height="20" alt="๐ฏ" />, or <img class="emoji" src="//telegram.org/img/emoji/40/F09F8F80.png" width="20" height="20" alt="๐" />, clients are supposed to behave differently both when sending and receiving such emojis: <a href="/api/dice">click here for more info ยป</a>.</p> +<h3><a class="anchor" href="#emojis-with-sounds" id="emojis-with-sounds" name="emojis-with-sounds"><i class="anchor-icon"></i></a>Emojis with sounds</h3> +<p>Certained animated emojis should play sound when clicked, as specified by <a href="/api/config#client-configuration">server-side configuration</a>. </p> +<p>The returned JSON object will contain the following map, with a list of file IDs to download:</p> +<pre><code> "emojies_sounds": { + "\ud83c\udf83": { + "id": "4956223179606458539", + "access_hash": "-2107001400913062971", + "file_reference_base64": "AF-4ApC7ukC0UWEPZN0TeSJURe7T" + }, + "\u26b0": { + "id": "4956223179606458540", + "access_hash": "-1498869544183595185", + "file_reference_base64": "AF-4ApCLKMGt96WCvLm58kbqZHd3" + }, + "\ud83e\udddf\u200d\u2642": { + "id": "4960929110848176331", + "access_hash": "3986395821757915468", + "file_reference_base64": "AF-4ApAedNln3IMEHH-SUQuH8L9g" + }, + }</code></pre> +<p>The <a href="/api/file_reference">file reference field</a> should be base64-decoded before <a href="/api/files">downloading the file</a>.</p> +<h3><a class="anchor" href="#emoji-reactions" id="emoji-reactions" name="emoji-reactions"><i class="anchor-icon"></i></a>Emoji reactions</h3> +<pre><code><a href='/constructor/inputStickerSetAnimatedEmojiAnimations'>inputStickerSetAnimatedEmojiAnimations</a>#cde3739 = <a href='/type/InputStickerSet'>InputStickerSet</a>; + +<a href='/constructor/messages.stickerSet'>messages.stickerSet</a>#b60a24a6 set:<a href='/type/StickerSet'>StickerSet</a> packs:<a href='/type/Vector%20t'>Vector</a><<a href='/type/StickerPack'>StickerPack</a>> documents:<a href='/type/Vector%20t'>Vector</a><<a href='/type/Document'>Document</a>> = <a href='/type/messages.StickerSet'>messages.StickerSet</a>; + +<a href='/constructor/stickerPack'>stickerPack</a>#12b299d4 emoticon:<a href='/type/string'>string</a> documents:<a href='/type/Vector%20t'>Vector</a><<a href='/type/long'>long</a>> = <a href='/type/StickerPack'>StickerPack</a>; + +<a href='/constructor/sendMessageEmojiInteraction'>sendMessageEmojiInteraction</a>#25972bcb emoticon:<a href='/type/string'>string</a> msg_id:<a href='/type/int'>int</a> interaction:<a href='/type/DataJSON'>DataJSON</a> = <a href='/type/SendMessageAction'>SendMessageAction</a>; +<a href='/constructor/sendMessageEmojiInteractionSeen'>sendMessageEmojiInteractionSeen</a>#b665902e emoticon:<a href='/type/string'>string</a> = <a href='/type/SendMessageAction'>SendMessageAction</a>; + +<a href='/constructor/updateUserTyping'>updateUserTyping</a>#c01e857f user_id:<a href='/type/long'>long</a> action:<a href='/type/SendMessageAction'>SendMessageAction</a> = <a href='/type/Update'>Update</a>; + +---functions--- + +<a href='/method/messages.getStickerSet'>messages.getStickerSet</a>#2619a90e stickerset:<a href='/type/InputStickerSet'>InputStickerSet</a> = <a href='/type/messages.StickerSet'>messages.StickerSet</a>; + +<a href='/method/messages.setTyping'>messages.setTyping</a>#58943ee2 flags:<a href='/type/%23'>#</a> peer:<a href='/type/InputPeer'>InputPeer</a> top_msg_id:flags.0?<a href='/type/int'>int</a> action:<a href='/type/SendMessageAction'>SendMessageAction</a> = <a href='/type/Bool'>Bool</a>;</code></pre> +<p>On startup, clients should fetch the animated reaction emoji stickerset by calling the <a href="/method/messages.getStickerSet">messages.getStickerSet</a> method, providing <a href="/constructor/inputStickerSetAnimatedEmojiAnimations">inputStickerSetAnimatedEmojiAnimations</a> to the <code>stickerset</code> field.<br> +The returned stickerset will contain a set of animated emoji reactions, <em>one or more</em> for each of the supported emojis.<br> +If a set of reactions for the <img class="emoji" src="//telegram.org/img/emoji/40/E29DA4.png" width="20" height="20" alt="โค" /> emoji is returned, the same reactions should also be assigned to the <img class="emoji" src="//telegram.org/img/emoji/40/F09FA7A1.png" width="20" height="20" alt="๐งก" />, <img class="emoji" src="//telegram.org/img/emoji/40/F09F929B.png" width="20" height="20" alt="๐" />, <img class="emoji" src="//telegram.org/img/emoji/40/F09F929A.png" width="20" height="20" alt="๐" />, <img class="emoji" src="//telegram.org/img/emoji/40/F09F9299.png" width="20" height="20" alt="๐" />, <img class="emoji" src="//telegram.org/img/emoji/40/F09F929C.png" width="20" height="20" alt="๐" />, <img class="emoji" src="//telegram.org/img/emoji/40/F09F96A4.png" width="20" height="20" alt="๐ค" />, <img class="emoji" src="//telegram.org/img/emoji/40/F09FA48D.png" width="20" height="20" alt="๐ค" /> and <img class="emoji" src="//telegram.org/img/emoji/40/F09FA48E.png" width="20" height="20" alt="๐ค" /> emojis. </p> +<p>Clients on both sides of private chats with users should overlay one of the appropriate reaction animations over the animated sticker when any of the two users clicks on a supported animated emoji.<br> +The reaction animation for each separate tap should be chosen randomly from all the available reactions for a given emoji, and multiple taps should be aggregated and sent to the other user as follows: </p> +<p>At each tap, clients should store all occurred taps in a local list.<br> +After 1 second has elapsed with no more taps, the local list should be cleared and stored taps should be sent using <a href="/method/messages.setTyping">messages.setTyping</a>, passing a <a href="/constructor/sendMessageEmojiInteraction">sendMessageEmojiInteraction</a> constructor with the following fields: </p> +<ul> +<li><code>emoticon</code> - The emoji we're reacting to</li> +<li><code>msg_id</code> - Message ID of the animated emoji that was clicked</li> +<li><code>interaction</code> - A JSON object with interaction info, containing the following keys:<ul> +<li><code>v</code> - An integer indicating the object version, currently <code>1</code></li> +<li><code>a</code> - An array of JSON objects, each containing the following keys:<ul> +<li><code>t</code> - float, number of seconds that passed since the previous tap in the array, the first tap uses a value of <code>0.0</code>.</li> +<li><code>i</code> - integer, 1-based index of the randomly chosen animation for the tap (equivalent to the index of a specific emoji-related animation in <a href="/constructor/stickerPack">stickerPack</a> + 1).</li> +</ul> +</li> +</ul> +</li> +</ul> +<p>1 second after the receiving user has seen the last reaction animation for a specific emoji, an acknowledgement must be sent using <a href="/method/messages.setTyping">messages.setTyping</a>, passing a <a href="/constructor/sendMessageEmojiInteractionSeen">sendMessageEmojiInteractionSeen</a> with that emoji.</p></div> + +</div> + + </div> + </div> + <div class="footer_wrap"> + <div class="footer_columns_wrap footer_desktop"> + <div class="footer_column footer_column_telegram"> + <h5>Telegram</h5> + <div class="footer_telegram_description"></div> + Telegram is a cloud-based mobile and desktop messaging app with a focus on security and speed. + </div> + + <div class="footer_column"> + <h5><a href="//telegram.org/faq">About</a></h5> + <ul> + <li><a href="//telegram.org/faq">FAQ</a></li> + <li><a href="//telegram.org/blog">Blog</a></li> + <li><a href="//telegram.org/jobs">Jobs</a></li> + </ul> + </div> + <div class="footer_column"> + <h5><a href="//telegram.org/apps#mobile-apps">Mobile Apps</a></h5> + <ul> + <li><a href="//telegram.org/dl/ios">iPhone/iPad</a></li> + <li><a href="//telegram.org/dl/android">Android</a></li> + <li><a href="//telegram.org/dl/wp">Windows Phone</a></li> + </ul> + </div> + <div class="footer_column"> + <h5><a href="//telegram.org/apps#desktop-apps">Desktop Apps</a></h5> + <ul> + <li><a href="//desktop.telegram.org/">PC/Mac/Linux</a></li> + <li><a href="//macos.telegram.org/">macOS</a></li> + <li><a href="//telegram.org/dl/web">Web-browser</a></li> + </ul> + </div> + <div class="footer_column footer_column_platform"> + <h5><a href="//core.telegram.org/">Platform</a></h5> + <ul> + <li><a href="//core.telegram.org/api">API</a></li> + <li><a href="//translations.telegram.org/">Translations</a></li> + <li><a href="//instantview.telegram.org/">Instant View</a></li> + </ul> + </div> + </div> + <div class="footer_columns_wrap footer_mobile"> + <div class="footer_column"> + <h5><a href="//telegram.org/faq">About</a></h5> + </div> + <div class="footer_column"> + <h5><a href="//telegram.org/blog">Blog</a></h5> + </div> + <div class="footer_column"> + <h5><a href="//telegram.org/apps">Apps</a></h5> + </div> + <div class="footer_column"> + <h5><a href="//core.telegram.org/">Platform</a></h5> + </div> + <div class="footer_column"> + <h5><a href="https://twitter.com/telegram" target="_blank" data-track="Follow/Twitter" onclick="trackDlClick(this, event)">Twitter</a></h5> + </div> + </div> +</div> + </div> + <script src="/js/main.js?43"></script> + + <script>backToTopInit("Go up"); +removePreloadInit(); +</script> + </body> +</html> +