This is a preview of the Tawasal Platform provided to selected partners. Please direct discussions to your respective group chats.
SDKs
Web


check our Documentation 👉 platform.tawasal.ae


npm Bundle Size Bundle Size

This library provides a set of functions to create mini-apps within the Tawasal SuperApp environment. It leverages various methods to interact with the Tawasal platform, including user interactions, device features, and app-specific functionalities.

Installation

npm i @tawasal/web

Usage

Haptic Feedback

haptic(pressure: "light" | "medium" | "heavy" | "soft" | "rigid")

Triggers haptic feedback with the specified pressure (haptic should be enabled on user side).

import { haptic } from "@tawasal/web";
 
for (const button of Array.from(document.getElementsByTagName("button"))) {
  button.onclick = () => haptic()
}

Navigation

open(destination: Destination)

Opens a specified destination within the Tawasal SuperApp (include the haptic for user experience).

closeApp()

Closes the mini-app.

User Interactions

openChat(userNickname: string)

Opens a chat with the specified user.

import { openChat } from "@tawasal/web";
 
openChat("@Aibot") // force user to visit Mellow

selectContacts(title: string): Promise<Contact[]>

Prompts the user to select contacts with a specified title for the selection dialog.

  import { selectContacts } from "@tawasal/web";
 
  selectContacts("title, to make users understand why they need to give contacts").then((value) => {
    if (value.length > 0) {
      addToStorage(value)
    }
  });

getUser(): Promise<Contact>

Fetches the user information. in provided scheme

{
  userId: number;
  firstName: string;
  lastName?: string;
  userNickname?: string;
  photoid?: bigint | null;
  photoaccesshash?: string | null;
  phone?: string;
}
import { getUser } from "@tawasal/web";
 
getUser().then((value) => {
  console.log(value.firstName ?? value.userNickname)
})

getUserPhoto(): Promise<base64String>

Fetches the user’s photo in base64 format.

import { getUserPhoto } from "@tawasal/web";
 
getUserPhoto().then((value) => {
  setSrc(value);
}); 

getPhoneNumber(reason: string): Promise<string>

Fetches the user’s phone number for a specified reason. (can be denied on user side if he don’t want to share phone with you)

import { getPhoneNumber } from "@tawasal/web";
 
getPhoneNumber("Provide title, so user will know why they should allow you their phone")
  .then((value) => {
    form.submit({ phone: value });
  });

Device Features

readClipboard(): Promise<string>

Reads the content of the clipboard.

Social

share({ text: string, url: string, imgUrl?: string })

Shares specified messages via the Tawasal SuperApp.

import { share } from "@tawasal/web";
 
share({
  text: `lets visit ${club.name} tonight!`, 
  url: club.url, 
  imgUrl: club.photo.src
})

QR Code

showScanQR(): Promise<string>

Shows the QR code scanner.

closeScanQR()

Closes the QR code scanner.

Helpers

checkIfImplemented(method: Method)

Checks if a method is implemented in the Tawasal SuperApp environment. It can help with the newest hooks, to check if user version supports it.

import { checkIfImplemented } from "@tawasal/web";
 
if (checkIfImplemented("selectContacts")) {
  // do select contacts
} else {
  // ask users to update app or provide alternative flow
}

getAvatar( photoId: string, photoAccessHash: string, id: number)

This method helps you receive avatars via API

import { selectContacts, getAvatar } from "@tawasal/web";
selectContacts("title").then((selectedUsers) => {
  if (selectedUsers[0]) {
    getAvatar(
      selectedUsers[0].userId,
      selectedUsers[0].photoid, 
      selectedUsers[0].photoaccesshash
    )
  }
});

you can also specify if you are searching channel avatar, and specific root url, for custom domain

getAvatar(
  channelId,
  photoid, 
  photoaccesshash, 
  "channel",
  "example.com"
)

Fixes for compabilty

Next.js

error: ESM packages need to be imported

add esm support to your next.js config

experimental: {
  esmExternals: "loose" 
}

License

Distributed under the MIT License. See LICENSE for more information.