Skip to content

MainButton

Implements Telegram Mini Apps Main Button.

Initialization

To initialize the component, use the initMainButton function:

typescript
import { initMainButton } from '@tma.js/sdk';

const [mainButton] = initMainButton();

Button Visibility

To control the Main Button visibility, developer could use such methods as show() and hide(). Both of them update component's isVisible property:

typescript
mainButton.show();
console.log(mainButton.isVisible); // true  

mainButton.hide();
console.log(mainButton.isVisible); // false

Loader

The Main Button could display a loader inside of it. To control its visibility, use showLoader() and hideLoader() methods. The isLoaderVisible property will be changed.

typescript
mainButton.showLoader();
console.log(mainButton.isLoaderVisible); // true  

mainButton.hideLoader();
console.log(mainButton.isLoaderVisible); // false

Active State

The Main Button can be enabled and disabled by calling disable() and enable() methods. Both of the methods will update the isEnabled property.

typescript
mainButton.enable();
console.log(mainButton.isEnabled); // true  

mainButton.disable();
console.log(mainButton.isEnabled); // false

Enabling the Main Button will allow a user to click it. As the result, the Main Button will receive the click event.

Background Color

To update the Main Button background color, use the setBackgroundColor(color: RGB) method. It will update the backgroundColor property.

typescript
mainButton.setBackgroundColor('#ffffaa');
console.log(mainButton.color); // '#ffffaa'

Text Color

To update the Main Button text color, use the setTextColor(color: RGB) method. It will update the textColor property.

typescript
mainButton.setTextColor('#cca233');
console.log(mainButton.textColor); // '#cca233'

Text

To update the Main Button text, use the setText(text: string) method. It will update the text property.

typescript
mainButton.setText('Submit');
console.log(mainButton.text); // 'Submit'

Setting Multiple Properties

Sometimes, a consecutive set of several Main Button parameters may lead to problematic artifacts in the UI. To avoid this issue, it is allowed to use the setParams method:

typescript
mainButton.setParams({
  backgroundColor: '#aa1388',
  text: 'Stop',
  isVisible: true,
});

Events

List of events, which could be tracked:

EventListenerTriggered when
click() => voidMain Button was clicked
change() => voidSomething in component changed
change:backgroundColor(value: RGB) => voidbackgroundColor property changed
change:isLoaderVisible(value: boolean) => voidisLoaderVisible property changed
change:isEnabled(value: boolean) => voidisEnabled property changed
change:isVisible(value: boolean) => voidisVisible property changed
change:text(value: string) => voidtext property changed
change:textColor(value: RGB) => voidtextColor property changed

Released under the MIT License.