MiniApp
The component which provides the common Telegram Mini Apps functionality not covered by other system components.
Initialization
The component constructor accepts an object with specified header and background colors, Telegram Mini Apps version, current bot inline mode, and an optional function to call Telegram Mini Apps methods.
headerColor: MiniAppHeaderColor; backgroundColor: RGB; version: Version; botInline: boolean; postEvent?: PostEvent;
import { MiniApp, postEvent } from '@tma.js/sdk';
const miniApp = new MiniApp({
headerColor: 'bg_color',
backgroundColor: '#00ae13',
version: '6.4',
botInline: false,
postEvent,
});
import { MiniApp, postEvent } from '@tma.js/sdk';
const miniApp = new MiniApp({
headerColor: 'bg_color',
backgroundColor: '#00ae13',
version: '6.4',
botInline: false,
postEvent,
});
Colors
Header
Developer is able to get and update Mini App header and background colors. To get current value of header color, developer could refer to the headerColor
property and update it via setHeaderColor
method:
console.log(miniApp.headerColor); // 'bg_color'
miniApp.setHeaderColor('secondary_bg_color');
// or starting from v6.10:
miniApp.setHeaderColor('#aa1132');
console.log(miniApp.headerColor); // 'bg_color'
miniApp.setHeaderColor('secondary_bg_color');
// or starting from v6.10:
miniApp.setHeaderColor('#aa1132');
Background
As well as Mini App header color, developer is also able to manipulate its background color:
console.log(miniApp.backgroundColor); // '#00ae13'
miniApp.setBackgroundColor('#888311');
console.log(miniApp.backgroundColor); // '#00ae13'
miniApp.setBackgroundColor('#888311');
Mini App background color is used to determine if current Mini App has dark palette. To know if current palette is dark, developer should use isDark
property:
console.log(miniApp.isDark); // false
console.log(miniApp.isDark); // false
Access Requests
Starting from Telegram Mini Apps version 6.9, Mini Apps are allowed to request access to the phone number and request access to write the current user. To do so, developers are allowed to use the requestPhoneAccess
and requestWriteAccess
methods:
miniApp.requestPhoneAccess().then(() => {
// done.
});
miniApp.requestWriteAccess().then(() => {
// done.
});
miniApp.requestPhoneAccess().then(() => {
// done.
});
miniApp.requestWriteAccess().then(() => {
// done.
});
To request the contact information (the phone number, for example), utilize the requestContact
method:
miniApp.requestContact().then(contact => {
console.log(contact);
// Output:
// {
// authDate: Date(...),
// hash: '...',
// contact: {
// firstName: '...',
// phoneNumber: '+38291789233',
// },
// };
});
miniApp.requestContact().then(contact => {
console.log(contact);
// Output:
// {
// authDate: Date(...),
// hash: '...',
// contact: {
// firstName: '...',
// phoneNumber: '+38291789233',
// },
// };
});
Inline Mode
Mini Apps are available to be launched in inline mode. When a Mini App is launched in such a mode, the developer is allowed to use the switchInlineQuery
method:
miniApp.switchInlineQuery('Show me something', ['users', 'groups']);
miniApp.switchInlineQuery('Show me something', ['users', 'groups']);
When calling this method, the Telegram application sends the bot username and the specified text to the chat selected by the user. The list of available chats will be restricted by the chat types specified in the second argument.
To check if the current Mini App is launched in inline mode, the developer should refer to the isBotInline
property:
console.log(miniApp.isBotInline); // false
console.log(miniApp.isBotInline); // false
Lifecycle Methods
ready
Informs the Telegram app that the Mini App is ready to be displayed.
It is recommended to call this method as early as possible, as soon as all essential interface elements loaded. Once this method called, the loading placeholder is hidden and the Mini App shown.
If the method not called, the placeholder will be hidden only when the page fully loaded.
miniApp.ready();
miniApp.ready();
close
Closes the Mini App.
miniApp.close();
miniApp.close();
Other Methods
sendData
A method used to send data to the bot. When this method is called, a service message is sent to the bot containing data of a length up to 4096 bytes, and the Mini App is closed. Refer to the web_app_data
field in the Message class.
Events
List of events, which could be used in on
and off
component instance methods:
Event | Listener | Triggered when |
---|---|---|
change | () => void | Something in component changed |
change:backgroundColor | (value: RGB) => void | backgroundColor property changed |
change:headerColor | (value: HeaderColorKey or RGB) => void | headerColor property changed |
Methods Support
List of methods, which could be used in supports
component instance method:
requestWriteAccess
requestPhoneAccess
switchInlineQuery
setHeaderColor
setBackgroundColor
miniApp.supports('requestWriteAccess');
miniApp.supports('requestPhoneAccess');
miniApp.supports('switchInlineQuery');
miniApp.supports('setHeaderColor');
miniApp.supports('setBackgroundColor');
miniApp.supports('requestWriteAccess');
miniApp.supports('requestPhoneAccess');
miniApp.supports('switchInlineQuery');
miniApp.supports('setHeaderColor');
miniApp.supports('setBackgroundColor');
Method Parameters Support
List of method parameters, which could be used in supportsParam
component instance method:
setHeaderColor.color
miniApp.supportsParam('setHeaderColor.color');
miniApp.supportsParam('setHeaderColor.color');