mirror of
https://github.com/MarshalX/telegram-crawler.git
synced 2025-01-16 22:53:12 +01:00
Update content of files
This commit is contained in:
parent
4f0932838f
commit
b0a07843ab
9 changed files with 4872 additions and 3567 deletions
|
@ -1,131 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html class="">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<title>Message drafts</title>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta property="description" content="How to handle message drafts">
|
|
||||||
<meta property="og:title" content="Message drafts">
|
|
||||||
<meta property="og:image" content="89f7ae8e51fc1ce19f">
|
|
||||||
<meta property="og:description" content="How to handle message drafts">
|
|
||||||
<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/drafts" >Message drafts</a></li></ul></div>
|
|
||||||
<h1 id="dev_page_title">Message drafts</h1>
|
|
||||||
|
|
||||||
<div id="dev_page_content"><!-- scroll_nav -->
|
|
||||||
|
|
||||||
<p>Message <a href="https://telegram.org/blog/drafts">drafts</a> in Telegram allow syncing the text typed into message fields between devices.</p>
|
|
||||||
<h3><a class="anchor" href="#drafts" id="drafts" name="drafts"><i class="anchor-icon"></i></a>Drafts</h3>
|
|
||||||
<p>Drafts are represented by the <a href="/type/DraftMessage">DraftMessage</a> constructors.
|
|
||||||
The parameters of the peer-specific draft should be used as defaults when composing a message to be sent to a certain peer (in the case of media, the same draft should still be used as base, the message will become the caption).
|
|
||||||
If the user exits the app before sending the message, the message should be saved as a draft:</p>
|
|
||||||
<h3><a class="anchor" href="#saving-drafts" id="saving-drafts" name="saving-drafts"><i class="anchor-icon"></i></a>Saving drafts</h3>
|
|
||||||
<p>Drafts can be saved using the <a href="/method/messages.saveDraft">messages.saveDraft</a> method.</p>
|
|
||||||
<h3><a class="anchor" href="#downloading-drafts" id="downloading-drafts" name="downloading-drafts"><i class="anchor-icon"></i></a>Downloading drafts</h3>
|
|
||||||
<p>New drafts are automatically sent to all devices via <a href="/constructor/updateDraftMessage">updateDraftMessage</a> updates.</p>
|
|
||||||
<p><a href="/constructor/dialog">Dialog</a> objects fetched via the API also contain the draft associated with the dialog.</p>
|
|
||||||
<h3><a class="anchor" href="#clearing-drafts" id="clearing-drafts" name="clearing-drafts"><i class="anchor-icon"></i></a>Clearing drafts</h3>
|
|
||||||
<p>Drafts can be cleared by setting the <code>clear_draft</code> flag when sending messages or media using <a href="/method/messages.sendMessage">messages.sendMessage</a>, <a href="/method/messages.sendMedia">messages.sendMedia</a>, <a href="/method/messages.sendMultiMedia">messages.sendMultiMedia</a>, <a href="/method/messages.sendInlineBotResult">messages.sendInlineBotResult</a> and similar or manually by passing empty values to <a href="/method/messages.saveDraft">messages.saveDraft</a>.</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="/">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 src="/js/jquery.min.js?1"></script>
|
|
||||||
<script src="/js/bootstrap.min.js?1"></script>
|
|
||||||
|
|
||||||
<script>window.initDevPageNav&&initDevPageNav();
|
|
||||||
backToTopInit("Go up");
|
|
||||||
removePreloadInit();
|
|
||||||
</script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
|
|
|
@ -1,132 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html class="">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<title>inputPrivacyKeyForwards</title>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta property="description" content="Whether messages forwarded from this user will be anonymous">
|
|
||||||
<meta property="og:title" content="inputPrivacyKeyForwards">
|
|
||||||
<meta property="og:image" content="">
|
|
||||||
<meta property="og:description" content="Whether messages forwarded from this user will be anonymous">
|
|
||||||
<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=""><a href="/api">API</a></li>
|
|
||||||
<li class=""><a href="/mtproto">Protocol</a></li>
|
|
||||||
<li class="active"><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="/schema" >TL-schema</a></li><i class="icon icon-breadcrumb-divider"></i><li><a href="/constructor/inputPrivacyKeyForwards" >inputPrivacyKeyForwards</a></li></ul></div>
|
|
||||||
<h1 id="dev_page_title">inputPrivacyKeyForwards</h1>
|
|
||||||
|
|
||||||
<div id="dev_page_content"><p>Whether messages forwarded from this user will be <a href="https://telegram.org/blog/unsend-privacy-emoji#anonymous-forwarding">anonymous</a></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 137 <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">133 – 64-bit IDs for User/Chat</a></li><li><a href="?layer=137"><strong>137 – reactions</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/inputPrivacyKeyForwards" class="current_page_link" >inputPrivacyKeyForwards</a>#a4dd4c08 = <a href="/type/InputPrivacyKey" >InputPrivacyKey</a>;</code></pre></p>
|
|
||||||
<h3><a class="anchor" href="#parameters" id="parameters" name="parameters"><i class="anchor-icon"></i></a>Parameters</h3>
|
|
||||||
<p>This constructor does not require any parameters.</p>
|
|
||||||
<h3><a class="anchor" href="#type" id="type" name="type"><i class="anchor-icon"></i></a>Type</h3>
|
|
||||||
<p><a href="/type/InputPrivacyKey">InputPrivacyKey</a></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="/">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>
|
|
||||||
|
|
|
@ -1,167 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html class="">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<title>messages.sentMessageLink</title>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta property="description" content="Info on successfully sent message and on changes links.">
|
|
||||||
<meta property="og:title" content="messages.sentMessageLink">
|
|
||||||
<meta property="og:image" content="">
|
|
||||||
<meta property="og:description" content="Info on successfully sent message and on changes links.">
|
|
||||||
<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=""><a href="/api">API</a></li>
|
|
||||||
<li class=""><a href="/mtproto">Protocol</a></li>
|
|
||||||
<li class="active"><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="/schema" >TL-schema</a></li><i class="icon icon-breadcrumb-divider"></i><li><a href="/constructor/messages.sentMessageLink" >messages.sentMessageLink</a></li></ul></div>
|
|
||||||
<h1 id="dev_page_title">messages.sentMessageLink</h1>
|
|
||||||
|
|
||||||
<div id="dev_page_content"><p>Info on successfully sent message and on changes links.</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 137 <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">133 – 64-bit IDs for User/Chat</a></li><li><a href="?layer=137"><strong>137 – reactions</strong></a></li>
|
|
||||||
<li class="divider"></li>
|
|
||||||
<li><a href="/api/layers">More...</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<pre class="page_scheme"><code>Constructor schema is available as of layer 24. <a href="?layer=24">Switch »</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>id</strong></td>
|
|
||||||
<td style="text-align: center;"><a href="/type/int">int</a></td>
|
|
||||||
<td>Message ID</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><strong>date</strong></td>
|
|
||||||
<td style="text-align: center;"><a href="/type/int">int</a></td>
|
|
||||||
<td>Date of sending</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><strong>pts</strong></td>
|
|
||||||
<td style="text-align: center;"><a href="/type/int">int</a></td>
|
|
||||||
<td>New value of <strong>pts</strong> parameter of a current state</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><strong>seq</strong></td>
|
|
||||||
<td style="text-align: center;"><a href="/type/int">int</a></td>
|
|
||||||
<td>New value of <strong>seq</strong> parameter of a current state</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><strong>links</strong></td>
|
|
||||||
<td style="text-align: center;"><a href="/type/Vector%20t">Vector</a><<a href="/type/contacts.Link">contacts.Link</a>></td>
|
|
||||||
<td>List of changes links</td>
|
|
||||||
</tr>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
<h3><a class="anchor" href="#type" id="type" name="type"><i class="anchor-icon"></i></a>Type</h3>
|
|
||||||
<p><a href="/type/messages.SentMessage">messages.SentMessage</a></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="/">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>
|
|
||||||
|
|
|
@ -1,168 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html class="">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<title>ChannelParticipant</title>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta property="description" content="Channel participant">
|
|
||||||
<meta property="og:title" content="ChannelParticipant">
|
|
||||||
<meta property="og:image" content="">
|
|
||||||
<meta property="og:description" content="Channel participant">
|
|
||||||
<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=""><a href="/api">API</a></li>
|
|
||||||
<li class=""><a href="/mtproto">Protocol</a></li>
|
|
||||||
<li class="active"><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="/schema" >TL-schema</a></li><i class="icon icon-breadcrumb-divider"></i><li><a href="/type/ChannelParticipant" >ChannelParticipant</a></li></ul></div>
|
|
||||||
<h1 id="dev_page_title">ChannelParticipant</h1>
|
|
||||||
|
|
||||||
<div id="dev_page_content"><p>Channel participant</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 137 <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">133 – 64-bit IDs for User/Chat</a></li><li><a href="?layer=137"><strong>137 – reactions</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/channelParticipant" >channelParticipant</a>#c00c07c0 user_id:<a href="/type/long" >long</a> date:<a href="/type/int" >int</a> = <a href="/type/ChannelParticipant" class="current_page_link" >ChannelParticipant</a>;
|
|
||||||
<a href="/constructor/channelParticipantSelf" >channelParticipantSelf</a>#35a8bfa7 flags:<a href="/type/%23" >#</a> via_request:flags.0?true user_id:<a href="/type/long" >long</a> inviter_id:<a href="/type/long" >long</a> date:<a href="/type/int" >int</a> = <a href="/type/ChannelParticipant" class="current_page_link" >ChannelParticipant</a>;
|
|
||||||
<a href="/constructor/channelParticipantCreator" >channelParticipantCreator</a>#2fe601d3 flags:<a href="/type/%23" >#</a> user_id:<a href="/type/long" >long</a> admin_rights:<a href="/type/ChatAdminRights" >ChatAdminRights</a> rank:flags.0?<a href="/type/string" >string</a> = <a href="/type/ChannelParticipant" class="current_page_link" >ChannelParticipant</a>;
|
|
||||||
<a href="/constructor/channelParticipantAdmin" >channelParticipantAdmin</a>#34c3bb53 flags:<a href="/type/%23" >#</a> can_edit:flags.0?true self:flags.1?true user_id:<a href="/type/long" >long</a> inviter_id:flags.1?<a href="/type/long" >long</a> promoted_by:<a href="/type/long" >long</a> date:<a href="/type/int" >int</a> admin_rights:<a href="/type/ChatAdminRights" >ChatAdminRights</a> rank:flags.2?<a href="/type/string" >string</a> = <a href="/type/ChannelParticipant" class="current_page_link" >ChannelParticipant</a>;
|
|
||||||
<a href="/constructor/channelParticipantBanned" >channelParticipantBanned</a>#6df8014e flags:<a href="/type/%23" >#</a> left:flags.0?true peer:<a href="/type/Peer" >Peer</a> kicked_by:<a href="/type/long" >long</a> date:<a href="/type/int" >int</a> banned_rights:<a href="/type/ChatBannedRights" >ChatBannedRights</a> = <a href="/type/ChannelParticipant" class="current_page_link" >ChannelParticipant</a>;
|
|
||||||
<a href="/constructor/channelParticipantLeft" >channelParticipantLeft</a>#1b03f006 peer:<a href="/type/Peer" >Peer</a> = <a href="/type/ChannelParticipant" class="current_page_link" >ChannelParticipant</a>;</code></pre></p>
|
|
||||||
<h3><a class="anchor" href="#constructors" id="constructors" name="constructors"><i class="anchor-icon"></i></a>Constructors</h3>
|
|
||||||
<table class="table">
|
|
||||||
<thead>
|
|
||||||
<tr>
|
|
||||||
<th>Constructor</th>
|
|
||||||
<th>Description</th>
|
|
||||||
</tr>
|
|
||||||
</thead>
|
|
||||||
<tbody>
|
|
||||||
<tr>
|
|
||||||
<td><a href="/constructor/channelParticipant">channelParticipant</a></td>
|
|
||||||
<td>Channel/supergroup participant</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><a href="/constructor/channelParticipantSelf">channelParticipantSelf</a></td>
|
|
||||||
<td>Myself</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><a href="/constructor/channelParticipantCreator">channelParticipantCreator</a></td>
|
|
||||||
<td>Channel/supergroup creator</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><a href="/constructor/channelParticipantAdmin">channelParticipantAdmin</a></td>
|
|
||||||
<td>Admin</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><a href="/constructor/channelParticipantBanned">channelParticipantBanned</a></td>
|
|
||||||
<td>Banned/kicked user</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><a href="/constructor/channelParticipantLeft">channelParticipantLeft</a></td>
|
|
||||||
<td>A participant that left the channel/supergroup</td>
|
|
||||||
</tr>
|
|
||||||
</tbody>
|
|
||||||
</table></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>
|
|
||||||
|
|
|
@ -1,128 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html class="">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<title>messages.SentMessage</title>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta property="description" content="Info on a successfully sent message.">
|
|
||||||
<meta property="og:title" content="messages.SentMessage">
|
|
||||||
<meta property="og:image" content="">
|
|
||||||
<meta property="og:description" content="Info on a successfully sent message.">
|
|
||||||
<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=""><a href="/api">API</a></li>
|
|
||||||
<li class=""><a href="/mtproto">Protocol</a></li>
|
|
||||||
<li class="active"><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="/schema" >TL-schema</a></li><i class="icon icon-breadcrumb-divider"></i><li><a href="/type/messages.SentMessage" >messages.SentMessage</a></li></ul></div>
|
|
||||||
<h1 id="dev_page_title">messages.SentMessage</h1>
|
|
||||||
|
|
||||||
<div id="dev_page_content"><p>Info on a successfully sent message.</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 137 <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">133 – 64-bit IDs for User/Chat</a></li><li><a href="?layer=137"><strong>137 – reactions</strong></a></li>
|
|
||||||
<li class="divider"></li>
|
|
||||||
<li><a href="/api/layers">More...</a></li>
|
|
||||||
</ul>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
<pre class="page_scheme"><code></code></pre></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="/">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>
|
|
||||||
|
|
|
@ -1,155 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html class="">
|
|
||||||
<head>
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<title>channelAdminLogEventActionParticipantToggleBan</title>
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
||||||
<meta property="description" content="The banned rights of a user were changed">
|
|
||||||
<meta property="og:title" content="channelAdminLogEventActionParticipantToggleBan">
|
|
||||||
<meta property="og:image" content="">
|
|
||||||
<meta property="og:description" content="The banned rights of a user were changed">
|
|
||||||
<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=""><a href="/api">API</a></li>
|
|
||||||
<li class=""><a href="/mtproto">Protocol</a></li>
|
|
||||||
<li class="active"><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="/schema" >TL-schema</a></li><i class="icon icon-breadcrumb-divider"></i><li><a href="/constructor/channelAdminLogEventActionParticipantToggleBan" >channelAdminLogEventActionParticipantToggleBan</a></li></ul></div>
|
|
||||||
<h1 id="dev_page_title">channelAdminLogEventActionParticipantToggleBan</h1>
|
|
||||||
|
|
||||||
<div id="dev_page_content"><p>The banned <a href="/api/rights">rights</a> of a user were changed</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 137 <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">133 – 64-bit IDs for User/Chat</a></li><li><a href="?layer=137"><strong>137 – reactions</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/channelAdminLogEventActionParticipantToggleBan" class="current_page_link" >channelAdminLogEventActionParticipantToggleBan</a>#e6d83d7e prev_participant:<a href="/type/ChannelParticipant" >ChannelParticipant</a> new_participant:<a href="/type/ChannelParticipant" >ChannelParticipant</a> = <a href="/type/ChannelAdminLogEventAction" >ChannelAdminLogEventAction</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>prev_participant</strong></td>
|
|
||||||
<td style="text-align: center;"><a href="/type/ChannelParticipant">ChannelParticipant</a></td>
|
|
||||||
<td>Old banned rights of user</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td><strong>new_participant</strong></td>
|
|
||||||
<td style="text-align: center;"><a href="/type/ChannelParticipant">ChannelParticipant</a></td>
|
|
||||||
<td>New banned rights of user</td>
|
|
||||||
</tr>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
<h3><a class="anchor" href="#type" id="type" name="type"><i class="anchor-icon"></i></a>Type</h3>
|
|
||||||
<p><a href="/type/ChannelAdminLogEventAction">ChannelAdminLogEventAction</a></p>
|
|
||||||
<h3><a class="anchor" href="#related-pages" id="related-pages" name="related-pages"><i class="anchor-icon"></i></a>Related pages</h3>
|
|
||||||
<h4><a class="anchor" href="#admin-banned-default-rights" id="admin-banned-default-rights" name="admin-banned-default-rights"><i class="anchor-icon"></i></a><a href="/api/rights">Admin, banned, default rights</a></h4>
|
|
||||||
<p>How to handle admin permissions, granular bans and global permissions in channels, groups and supergroups.</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>
|
|
||||||
|
|
|
@ -1,685 +0,0 @@
|
||||||
var startTime = +(new Date());
|
|
||||||
function dT() {
|
|
||||||
return '[' + ((+(new Date()) - startTime)/ 1000.0) + '] ';
|
|
||||||
}
|
|
||||||
|
|
||||||
var jsonpCallbacks = [];
|
|
||||||
function twitterCustomShareInit () {
|
|
||||||
var btns = document.querySelectorAll
|
|
||||||
? document.querySelectorAll('.tl_twitter_share_btn')
|
|
||||||
: [document.getElementById('tl_twitter_share_btn')];
|
|
||||||
|
|
||||||
if (!btns.length) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var head = document.getElementsByTagName('head')[0], i, script;
|
|
||||||
for (i = 0; i < btns.length; i++) {
|
|
||||||
(function (btn) {
|
|
||||||
var status = btn.getAttribute('data-text'),
|
|
||||||
url = btn.getAttribute('data-url') || location.toString() || 'https://telegram.org/',
|
|
||||||
via = btn.getAttribute('data-via'),
|
|
||||||
urlEncoded = encodeURIComponent(url),
|
|
||||||
popupUrl = 'https://twitter.com/intent/tweet?text=' + encodeURIComponent(status) + '&url=' + urlEncoded + '&via=' + encodeURIComponent(via);
|
|
||||||
|
|
||||||
btn.setAttribute('href', popupUrl);
|
|
||||||
btn.href = popupUrl;
|
|
||||||
|
|
||||||
btn.addEventListener('click', function (e) {
|
|
||||||
var popupW = 550,
|
|
||||||
popupH = 450,
|
|
||||||
params = [
|
|
||||||
'width=' + popupW,
|
|
||||||
'height=' + popupH,
|
|
||||||
'left=' + Math.round(screen.width / 2 - popupW / 2),
|
|
||||||
'top=' + Math.round(screen.height / 2 - popupH / 2),
|
|
||||||
'personalbar=0',
|
|
||||||
'toolbar=0',
|
|
||||||
'scrollbars=1',
|
|
||||||
'resizable=1'
|
|
||||||
].join(','),
|
|
||||||
popup = window.open(popupUrl, '_blank', params);
|
|
||||||
|
|
||||||
if (popup) {
|
|
||||||
try {
|
|
||||||
popup.focus();
|
|
||||||
} catch (e) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
return cancelEvent(e);
|
|
||||||
}, false);
|
|
||||||
})(btns[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function blogRecentNewsInit () {
|
|
||||||
if (document.querySelectorAll) {
|
|
||||||
var sideImages = document.querySelectorAll('.blog_side_image_wrap');
|
|
||||||
var sideImage, parent, i;
|
|
||||||
var len = len = sideImages.length;
|
|
||||||
for (i = 0; i < len; i++) {
|
|
||||||
sideImage = sideImages[i];
|
|
||||||
parent = sideImage.parentNode.parentNode;
|
|
||||||
if (parent) {
|
|
||||||
parent.insertBefore(sideImage, parent.firstChild);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var moreBtn = document.getElementById('tlb_blog_head_more_link');
|
|
||||||
if (!moreBtn) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var activeClassName = 'tlb_blog_head_recent_active';
|
|
||||||
moreBtn.addEventListener('click', function (event) {
|
|
||||||
var parent = this.parentNode;
|
|
||||||
var className = parent.className;
|
|
||||||
if (className.indexOf(activeClassName) == -1) {
|
|
||||||
className += ' ' + activeClassName;
|
|
||||||
} else {
|
|
||||||
className = className.replace(' ' + activeClassName, '');
|
|
||||||
}
|
|
||||||
parent.className = className;
|
|
||||||
|
|
||||||
return cancelEvent(event);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function blogSideImageUpdate(argument) {
|
|
||||||
var isDesktop = document.documentElement.offsetWidth >= 1000
|
|
||||||
document.querySelectorAll('.blog_side_image_wrap').forEach(function (imageWrap) {
|
|
||||||
if (isDesktop) {
|
|
||||||
var titleHeight = imageWrap.parentNode.previousElementSibling.clientHeight;
|
|
||||||
var beforeTitleEl = imageWrap.parentNode.previousElementSibling.previousElementSibling;
|
|
||||||
if (beforeTitleEl) {
|
|
||||||
titleHeight += beforeTitleEl.clientHeight;
|
|
||||||
}
|
|
||||||
imageWrap.firstElementChild.style.marginTop = (-titleHeight - 8) + 'px';
|
|
||||||
} else {
|
|
||||||
imageWrap.firstElementChild.style.marginTop = '';
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
function blogSideImageInit() {
|
|
||||||
window.addEventListener('resize', blogSideImageUpdate, false);
|
|
||||||
setTimeout(blogSideImageUpdate, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
function cancelEvent (event) {
|
|
||||||
event = event || window.event;
|
|
||||||
if (event) event = event.originalEvent || event;
|
|
||||||
|
|
||||||
if (event.stopPropagation) event.stopPropagation();
|
|
||||||
if (event.preventDefault) event.preventDefault();
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function trackDlClick (element, event) {
|
|
||||||
var href = element.getAttribute('href'),
|
|
||||||
track = element.getAttribute('data-track') || false;
|
|
||||||
|
|
||||||
if (!track || !window.ga) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var trackData = track.toString().split('/');
|
|
||||||
|
|
||||||
ga('send', 'event', trackData[0], trackData[1], href);
|
|
||||||
|
|
||||||
if ((element.getAttribute('target') || '').toLowerCase() != '_blank') {
|
|
||||||
setTimeout(function() { location.href = href; }, 200);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var toTopWrapEl,
|
|
||||||
toTopEl,
|
|
||||||
pageContentWrapEl,
|
|
||||||
curVisible,
|
|
||||||
curShown = false;
|
|
||||||
function backToTopInit (labelHtml) {
|
|
||||||
pageContentWrapEl = document.getElementById('dev_page_content_wrap');
|
|
||||||
if (!pageContentWrapEl) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
var t = document.createElement('div');
|
|
||||||
|
|
||||||
t.innerHTML = '<div class="back_to_top"><i class="icon icon-to-top"></i>' + labelHtml + '</div>';
|
|
||||||
toTopEl = t.firstChild;
|
|
||||||
t.innerHTML = '<a class="back_to_top_wrap' + (pageContentWrapEl.classList.contains('is_rtl') ? ' is_rtl' : '') + '" onclick="backToTopGo()"></a>';
|
|
||||||
toTopWrapEl = t.firstChild;
|
|
||||||
|
|
||||||
toTopWrapEl.appendChild(toTopEl);
|
|
||||||
document.body.appendChild(toTopWrapEl);
|
|
||||||
|
|
||||||
if (window.addEventListener) {
|
|
||||||
window.addEventListener('resize', backToTopResize, false);
|
|
||||||
window.addEventListener('scroll', backToTopScroll, false);
|
|
||||||
}
|
|
||||||
backToTopResize();
|
|
||||||
}
|
|
||||||
|
|
||||||
function backToTopGo () {
|
|
||||||
window.scroll(0, 0);
|
|
||||||
backToTopScroll();
|
|
||||||
}
|
|
||||||
|
|
||||||
function backToTopResize () {
|
|
||||||
var left = getXY(pageContentWrapEl)[0],
|
|
||||||
dwidth = Math.max(window.innerWidth, document.documentElement.clientWidth, 0),
|
|
||||||
dheight = Math.max(window.innerHeight, document.documentElement.clientHeight);
|
|
||||||
|
|
||||||
curVisible = pageContentWrapEl && left > 130 && dwidth > 640;
|
|
||||||
toTopWrapEl.style.width = left + 'px';
|
|
||||||
toTopEl.style.height = dheight + 'px';
|
|
||||||
backToTopScroll();
|
|
||||||
}
|
|
||||||
|
|
||||||
function backToTopScroll () {
|
|
||||||
var st = window.pageYOffset || document.body.scrollTop || document.documentElement.scrollTop || document.documentElement.scrollTop;
|
|
||||||
if ((st > 400 && curVisible) != curShown) {
|
|
||||||
curShown = !curShown;
|
|
||||||
if (curShown) {
|
|
||||||
toTopWrapEl.classList.add('back_to_top_shown');
|
|
||||||
} else {
|
|
||||||
toTopWrapEl.classList.remove('back_to_top_shown');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function removePreloadInit() {
|
|
||||||
if (window.addEventListener) {
|
|
||||||
window.addEventListener('load', function () {
|
|
||||||
document.body.classList.remove('preload');
|
|
||||||
}, false);
|
|
||||||
} else {
|
|
||||||
setTimeout(function () {
|
|
||||||
document.body.classList.remove('preload');
|
|
||||||
}, 1000)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function getXY (obj) {
|
|
||||||
if (!obj) return [0, 0];
|
|
||||||
|
|
||||||
var left = 0, top = 0;
|
|
||||||
if (obj.offsetParent) {
|
|
||||||
do {
|
|
||||||
left += obj.offsetLeft;
|
|
||||||
top += obj.offsetTop;
|
|
||||||
} while (obj = obj.offsetParent);
|
|
||||||
}
|
|
||||||
return [left, top];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var onDdBodyClick,
|
|
||||||
currentDd;
|
|
||||||
function dropdownClick (element, event) {
|
|
||||||
var parent = element.parentNode;
|
|
||||||
var isOpen = (parent.className || '').indexOf('open') > 0;
|
|
||||||
if (currentDd && currentDd != parent) {
|
|
||||||
dropdownHide(currentDd);
|
|
||||||
}
|
|
||||||
if (!isOpen) {
|
|
||||||
parent.className = (parent.className || '') + ' open';
|
|
||||||
if (!onDdBodyClick) {
|
|
||||||
window.addEventListener('click', dropdownPageClick, false);
|
|
||||||
}
|
|
||||||
currentDd = parent;
|
|
||||||
} else {
|
|
||||||
dropdownHide(currentDd);
|
|
||||||
currentDd = false;
|
|
||||||
}
|
|
||||||
event.cancelBubble = true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function dropdownHide (parent) {
|
|
||||||
parent.className = parent.className.replace(' open', '');
|
|
||||||
}
|
|
||||||
|
|
||||||
function dropdownPageClick (event) {
|
|
||||||
if (currentDd) {
|
|
||||||
dropdownHide(currentDd);
|
|
||||||
currentDd = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function escapeHTML (html) {
|
|
||||||
html = html || '';
|
|
||||||
return html.replace(/&/g, '&')
|
|
||||||
.replace(/>/g, '>')
|
|
||||||
.replace(/</g, '<')
|
|
||||||
.replace(/"/g, '"')
|
|
||||||
.replace(/'/g, ''');
|
|
||||||
}
|
|
||||||
|
|
||||||
function videoTogglePlay(el) {
|
|
||||||
if (el.paused) {
|
|
||||||
el.play();
|
|
||||||
} else {
|
|
||||||
el.pause();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function getDevPageNav() {
|
|
||||||
// console.time('page nav');
|
|
||||||
var menu = $('<ul class="nav navbar-nav navbar-default"></ul>');
|
|
||||||
var lastLi = false;
|
|
||||||
var items = 0;
|
|
||||||
$('a.anchor').each(function (k, anchor) {
|
|
||||||
var parentTag = anchor.parentNode.tagName;
|
|
||||||
var matches = parentTag.match(/^h([34])$/i);
|
|
||||||
var anchorName = anchor.name;
|
|
||||||
if (!matches || !anchorName) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
anchor.id = anchor.name;
|
|
||||||
var level = parseInt(matches[1]);
|
|
||||||
var li = $('<li><a href="#'+ anchorName +'" data-target="#'+ anchorName +'" onmouseenter="showTitleIfOverflows(this)">' + escapeHTML(anchor.nextSibling.textContent) + '</a></li>');
|
|
||||||
if (level == 3) {
|
|
||||||
li.appendTo(menu);
|
|
||||||
lastLi = li;
|
|
||||||
} else {
|
|
||||||
// console.log(lastLi);
|
|
||||||
if (!lastLi) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var subMenu = $('ul', lastLi)[0] || $('<ul class="nav"></ul>').appendTo(lastLi);
|
|
||||||
// console.log(subMenu);
|
|
||||||
li.appendTo(subMenu);
|
|
||||||
}
|
|
||||||
items++;
|
|
||||||
});
|
|
||||||
// console.log(items, menu);
|
|
||||||
// console.timeEnd('page nav');
|
|
||||||
if (items < 2) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return menu;
|
|
||||||
}
|
|
||||||
|
|
||||||
function showTitleIfOverflows(element) {
|
|
||||||
if (element &&
|
|
||||||
element.innerText &&
|
|
||||||
element.scrollWidth &&
|
|
||||||
element.offsetWidth &&
|
|
||||||
element.offsetWidth < element.scrollWidth) {
|
|
||||||
element.setAttribute('title', element.innerText);
|
|
||||||
}
|
|
||||||
else if (element.removeAttribute) {
|
|
||||||
element.removeAttribute('title');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function initDevPageNav() {
|
|
||||||
window.hasDevPageNav = true;
|
|
||||||
var menu = getDevPageNav();
|
|
||||||
if (!menu) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var sideNavCont = $('#dev_side_nav_cont');
|
|
||||||
if (!sideNavCont.length) {
|
|
||||||
sideNavCont = $('#dev_page_content_wrap');
|
|
||||||
}
|
|
||||||
var sideNavWrap = $('<div class="dev_side_nav_wrap"></div>').prependTo(sideNavCont);
|
|
||||||
var sideNav = $('<div class="dev_side_nav"></div>').appendTo(sideNavWrap);
|
|
||||||
menu.appendTo(sideNav);
|
|
||||||
$('body').css({position: 'relative'}).scrollspy({ target: '.dev_side_nav' });
|
|
||||||
|
|
||||||
$('body').on('activate.bs.scrollspy', function () {
|
|
||||||
$('.dev_side_nav > ul').affix('checkPosition');
|
|
||||||
var active_el = $('.dev_side_nav li.active').get(-1);
|
|
||||||
if (active_el) {
|
|
||||||
if (active_el.scrollIntoViewIfNeeded) {
|
|
||||||
active_el.scrollIntoViewIfNeeded();
|
|
||||||
} else if (active_el.scrollIntoView) {
|
|
||||||
active_el.scrollIntoView(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
$('body').trigger('activate.bs.scrollspy');
|
|
||||||
|
|
||||||
updateMenuAffix(menu);
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateDevPageNav() {
|
|
||||||
if (!window.hasDevPageNav) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
var menu = getDevPageNav() || $('<ul></ul>');
|
|
||||||
$('.dev_side_nav > ul').replaceWith(menu);
|
|
||||||
$('body').scrollspy('refresh');
|
|
||||||
updateMenuAffix(menu);
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateMenuAffix(menu) {
|
|
||||||
menu.affix({
|
|
||||||
offset: {
|
|
||||||
top: function () {
|
|
||||||
return $('.dev_side_nav_wrap').offset().top;
|
|
||||||
},
|
|
||||||
bottom: function () {
|
|
||||||
return (this.bottom = $('.footer_wrap').outerHeight(true) + 20)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function initScrollVideos(desktop) {
|
|
||||||
var videos = document.querySelectorAll
|
|
||||||
? document.querySelectorAll('video.tl_blog_vid_autoplay')
|
|
||||||
: [];
|
|
||||||
|
|
||||||
window.pageVideos = Array.prototype.slice.apply(videos);
|
|
||||||
if (!pageVideos.length) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
window.pageVideosPlaying = {};
|
|
||||||
|
|
||||||
var index = 1;
|
|
||||||
var tgStickersCnt = document.querySelectorAll('.js-tgsticker_image').length;
|
|
||||||
var preloadVideos = tgStickersCnt ? 0 : 2;
|
|
||||||
for (var i = 0; i < pageVideos.length; i++) {
|
|
||||||
var videoEl = pageVideos[i];
|
|
||||||
videoEl.setAttribute('vindex', index++);
|
|
||||||
var preloadValue = i >= preloadVideos ? 'metadata' : 'auto';
|
|
||||||
videoEl.setAttribute('preload', preloadValue);
|
|
||||||
videoEl.preload = preloadValue;
|
|
||||||
if (desktop) {
|
|
||||||
videoEl.removeAttribute('controls');
|
|
||||||
videoEl.autoplay = false;
|
|
||||||
videoEl.removeAttribute('autoplay');
|
|
||||||
} else {
|
|
||||||
videoEl.autoplay = true;
|
|
||||||
videoEl.playsinline = true;
|
|
||||||
videoEl.setAttribute('autoplay', 'autoplay');
|
|
||||||
videoEl.setAttribute('playsinline', 'playsinline');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!desktop) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
window.addEventListener('scroll', checkScrollVideos, false);
|
|
||||||
window.addEventListener('resize', checkScrollVideos, false);
|
|
||||||
setTimeout(checkScrollVideos, 1000);
|
|
||||||
}
|
|
||||||
|
|
||||||
function checkScrollVideos() {
|
|
||||||
var w = window,
|
|
||||||
d = document,
|
|
||||||
e = d.documentElement,
|
|
||||||
g = d.getElementsByTagName('body')[0],
|
|
||||||
winWidth = w.innerWidth || e.clientWidth || g.clientWidth,
|
|
||||||
winHeight = w.innerHeight|| e.clientHeight|| g.clientHeight,
|
|
||||||
scrollTop = e.scrollTop || g.scrollTop || w.pageYOffset;
|
|
||||||
|
|
||||||
for (var i = 0; i < pageVideos.length; i++) {
|
|
||||||
var videoEl = pageVideos[i];
|
|
||||||
var curIndex = videoEl.getAttribute('vindex');
|
|
||||||
var posY = getFullOffsetY(videoEl);
|
|
||||||
var height = videoEl.offsetHeight;
|
|
||||||
// console.log(scrollTop, winHeight, posY, height);
|
|
||||||
|
|
||||||
|
|
||||||
if (isVisibleEnough(posY, height, scrollTop, winHeight, 0.7, 0.9)) {
|
|
||||||
if (!pageVideosPlaying[curIndex]) {
|
|
||||||
pageVideosPlaying[curIndex] = true;
|
|
||||||
console.log('play', videoEl);
|
|
||||||
videoEl.play();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (pageVideosPlaying[curIndex]) {
|
|
||||||
delete pageVideosPlaying[curIndex];
|
|
||||||
console.log('pause', videoEl);
|
|
||||||
videoEl.pause();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function isVisibleEnough(boxOffset, boxSize, viewOffset, viewSize, boxThreshold, viewThreshold) {
|
|
||||||
var boxEnd = boxOffset + boxSize;
|
|
||||||
var viewEnd = viewOffset + viewSize;
|
|
||||||
var viewBox = Math.min(viewEnd, boxEnd) - Math.max(boxOffset, viewOffset);
|
|
||||||
if (viewBox < 0) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (viewBox / boxSize > boxThreshold) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (viewThreshold && viewBox / viewSize > viewThreshold) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
function getFullOffsetY(el) {
|
|
||||||
var offsetTop = el.offsetTop || 0;
|
|
||||||
if (el.offsetParent) {
|
|
||||||
offsetTop += getFullOffsetY(el.offsetParent);
|
|
||||||
}
|
|
||||||
return offsetTop;
|
|
||||||
}
|
|
||||||
|
|
||||||
function redraw(el) {
|
|
||||||
el.offsetTop + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
function initRipple() {
|
|
||||||
if (!document.querySelectorAll) return;
|
|
||||||
var rippleTextFields = document.querySelectorAll('.textfield-item input.form-control');
|
|
||||||
for (var i = 0; i < rippleTextFields.length; i++) {
|
|
||||||
(function(rippleTextField) {
|
|
||||||
function onTextRippleStart(e) {
|
|
||||||
if (document.activeElement === rippleTextField) return;
|
|
||||||
var rect = rippleTextField.getBoundingClientRect();
|
|
||||||
if (e.type == 'touchstart') {
|
|
||||||
var clientX = e.targetTouches[0].clientX;
|
|
||||||
} else {
|
|
||||||
var clientX = e.clientX;
|
|
||||||
}
|
|
||||||
var ripple = rippleTextField.parentNode.querySelector('.textfield-item-underline');
|
|
||||||
var rippleX = (clientX - rect.left) / rippleTextField.offsetWidth * 100;
|
|
||||||
ripple.style.transition = 'none';
|
|
||||||
redraw(ripple);
|
|
||||||
ripple.style.left = rippleX + '%';
|
|
||||||
ripple.style.right = (100 - rippleX) + '%';
|
|
||||||
redraw(ripple);
|
|
||||||
ripple.style.left = '';
|
|
||||||
ripple.style.right = '';
|
|
||||||
ripple.style.transition = '';
|
|
||||||
}
|
|
||||||
rippleTextField.removeEventListener('mousedown', onTextRippleStart);
|
|
||||||
rippleTextField.removeEventListener('touchstart', onTextRippleStart);
|
|
||||||
rippleTextField.addEventListener('mousedown', onTextRippleStart);
|
|
||||||
rippleTextField.addEventListener('touchstart', onTextRippleStart);
|
|
||||||
})(rippleTextFields[i]);
|
|
||||||
}
|
|
||||||
var rippleHandlers = document.querySelectorAll('.ripple-handler');
|
|
||||||
for (var i = 0; i < rippleHandlers.length; i++) {
|
|
||||||
(function(rippleHandler) {
|
|
||||||
function onRippleStart(e) {
|
|
||||||
var rippleMask = rippleHandler.querySelector('.ripple-mask');
|
|
||||||
if (!rippleMask) return;
|
|
||||||
var rect = rippleMask.getBoundingClientRect();
|
|
||||||
if (e.type == 'touchstart') {
|
|
||||||
var clientX = e.targetTouches[0].clientX;
|
|
||||||
var clientY = e.targetTouches[0].clientY;
|
|
||||||
} else {
|
|
||||||
var clientX = e.clientX;
|
|
||||||
var clientY = e.clientY;
|
|
||||||
}
|
|
||||||
var rippleX = (clientX - rect.left) - rippleMask.offsetWidth / 2;
|
|
||||||
var rippleY = (clientY - rect.top) - rippleMask.offsetHeight / 2;
|
|
||||||
var ripple = rippleHandler.querySelector('.ripple');
|
|
||||||
ripple.style.transition = 'none';
|
|
||||||
redraw(ripple);
|
|
||||||
ripple.style.transform = 'translate3d(' + rippleX + 'px, ' + rippleY + 'px, 0) scale3d(0.2, 0.2, 1)';
|
|
||||||
ripple.style.opacity = 1;
|
|
||||||
redraw(ripple);
|
|
||||||
ripple.style.transform = 'translate3d(' + rippleX + 'px, ' + rippleY + 'px, 0) scale3d(1, 1, 1)';
|
|
||||||
ripple.style.transition = '';
|
|
||||||
|
|
||||||
function onRippleEnd(e) {
|
|
||||||
ripple.style.transitionDuration = '.2s';
|
|
||||||
ripple.style.opacity = 0;
|
|
||||||
document.removeEventListener('mouseup', onRippleEnd);
|
|
||||||
document.removeEventListener('touchend', onRippleEnd);
|
|
||||||
document.removeEventListener('touchcancel', onRippleEnd);
|
|
||||||
}
|
|
||||||
document.addEventListener('mouseup', onRippleEnd);
|
|
||||||
document.addEventListener('touchend', onRippleEnd);
|
|
||||||
document.addEventListener('touchcancel', onRippleEnd);
|
|
||||||
}
|
|
||||||
rippleHandler.removeEventListener('mousedown', onRippleStart);
|
|
||||||
rippleHandler.removeEventListener('touchstart', onRippleStart);
|
|
||||||
rippleHandler.addEventListener('mousedown', onRippleStart);
|
|
||||||
rippleHandler.addEventListener('touchstart', onRippleStart);
|
|
||||||
})(rippleHandlers[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function mainInitRetinaVideos() {
|
|
||||||
var videoEls = document.querySelectorAll('video.video__init_retina');
|
|
||||||
var isRetina = window.devicePixelRatio >= 1.5;
|
|
||||||
var videoEl, i, badChildren, j, badChild, sources, sourceEl;
|
|
||||||
for (i = 0; i < videoEls.length; i++) {
|
|
||||||
videoEl = videoEls[i];
|
|
||||||
sources = (videoEl.getAttribute('data-sources')||'').split(',');
|
|
||||||
sourceEl = document.createElement('source');
|
|
||||||
sourceEl.type = 'video/mp4';
|
|
||||||
sourceEl.src = sources[isRetina ? 1 : 0];
|
|
||||||
videoEl.appendChild(sourceEl);
|
|
||||||
videoEl.classList.remove('video__init_retina');
|
|
||||||
videoEl.setAttribute('preload', 'auto');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function mainInitDemoAutoplay(videoLinkElsSelector) {
|
|
||||||
var videoLinkEls = document.querySelectorAll(videoLinkElsSelector);
|
|
||||||
var videoLinkEl, videoEl, i;
|
|
||||||
for (i = 0; i < videoLinkEls.length; i++) {
|
|
||||||
videoLinkEl = videoLinkEls[i];
|
|
||||||
videoEl = videoLinkEl.querySelector('video');
|
|
||||||
if (!videoEl) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (videoEl.readyState > 1) {
|
|
||||||
mainDemoVideoHover(videoLinkEl, 1);
|
|
||||||
} else {
|
|
||||||
videoEl.load();
|
|
||||||
videoEl.addEventListener('loadeddata', (function(el) {
|
|
||||||
return function () {
|
|
||||||
setTimeout(function () {
|
|
||||||
mainDemoVideoHover(el, 1);
|
|
||||||
}, 0)
|
|
||||||
}
|
|
||||||
})(videoLinkEl), false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function mainDemoVideoHover(videoLinkEl, isHover) {
|
|
||||||
var outTimeout = videoLinkEl.outTimeout;
|
|
||||||
var curIsHover = videoLinkEl.isHover || 0;
|
|
||||||
if (outTimeout) {
|
|
||||||
clearTimeout(outTimeout);
|
|
||||||
}
|
|
||||||
if (curIsHover == isHover) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!isHover) {
|
|
||||||
outTimeout = setTimeout(function () {
|
|
||||||
mainDemoVideoDoHover(videoLinkEl, isHover)
|
|
||||||
}, 100);
|
|
||||||
videoLinkEl.outTimeout = outTimeout;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
mainDemoVideoDoHover(videoLinkEl, isHover);
|
|
||||||
}
|
|
||||||
|
|
||||||
function mainDemoVideoDoHover(videoLinkEl, isHover) {
|
|
||||||
delete videoLinkEl.outTimeout;
|
|
||||||
|
|
||||||
var videoEl = videoLinkEl.querySelector('video');
|
|
||||||
if (isHover) {
|
|
||||||
if (videoEl.readyState > 1) {
|
|
||||||
videoLinkEl.classList.add('video_play');
|
|
||||||
videoEl.play();
|
|
||||||
videoLinkEl.isHover = 1;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
videoLinkEl.isHover = 0;
|
|
||||||
}
|
|
||||||
if (!videoEl.inited) {
|
|
||||||
videoEl.inited = true;
|
|
||||||
// videoEl.onended =
|
|
||||||
videoEl.addEventListener('ended', function onVideoEnded(e) {
|
|
||||||
if (videoLinkEl.isHover) {
|
|
||||||
videoEl.currentTime = 0;
|
|
||||||
videoEl.play();
|
|
||||||
} else {
|
|
||||||
videoEl.pause();
|
|
||||||
videoEl.currentTime = 0;
|
|
||||||
videoLinkEl.classList.remove('video_play')
|
|
||||||
}
|
|
||||||
}, false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function mainInitTgStickers(options) {
|
|
||||||
options = options || {};
|
|
||||||
if (!RLottie.isSupported) {
|
|
||||||
if (options.unsupportedURL) {
|
|
||||||
if (!getCookie('stel_notgs')) {
|
|
||||||
setCookie('stel_notgs', 1, 7);
|
|
||||||
}
|
|
||||||
location = options.unsupportedURL;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
document.querySelectorAll('.js-tgsticker_image').forEach(function (imgEl) {
|
|
||||||
RLottie.init(imgEl, options);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function setCookie(name, value, days) {
|
|
||||||
var expires = '';
|
|
||||||
if (days) {
|
|
||||||
var date = new Date();
|
|
||||||
date.setTime(date.getTime() + (days * 86400000));
|
|
||||||
expires = "; expires=" + date.toUTCString();
|
|
||||||
}
|
|
||||||
document.cookie = name + "=" + (value || "") + expires + "; path=/";
|
|
||||||
}
|
|
||||||
|
|
||||||
function getCookie(name) {
|
|
||||||
var nameEQ = name + '=';
|
|
||||||
var ca = document.cookie.split(';');
|
|
||||||
for (var i = 0; i < ca.length; i++) {
|
|
||||||
var c = ca[i];
|
|
||||||
while (c.charAt(0) == ' ') {
|
|
||||||
c = c.substr(1, c.length);
|
|
||||||
}
|
|
||||||
if (c.indexOf(nameEQ) == 0) {
|
|
||||||
return c.substr(nameEQ.length, c.length);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
function mainScrollTo(element) {
|
|
||||||
if (typeof element === 'string') {
|
|
||||||
element = document.querySelector(element)
|
|
||||||
}
|
|
||||||
if (element) {
|
|
||||||
window.scroll(0, getFullOffsetY(element));
|
|
||||||
}
|
|
||||||
}
|
|
4872
data/macos.telegram.org/css/telegram.css
Normal file
4872
data/macos.telegram.org/css/telegram.css
Normal file
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue