Skip to content

andrey-lazarev/smartapp-bridge

 
 

Repository files navigation

SmartApp bridge library

This library provides a universal interface for exchanging events with an express client. Andriod, iOS and Web clients supported.

All types can be found here.

Send event to eXpress

SmartAppBridge
  .sendClientEvent(
    {
      method: 'get_weather',
      params: {
        city: 'Moscow',
      },
      files: []
    }
  )
  .then(data => {
    // Handle response
    console.log('response', data)
  })
  .then(({ type: method, handler: express, payload: params, files }) => {
    // Handle response data type, payload
  })
  .catch(() => {
    // Do something on timeout
  })
SmartAppBridge
  .sendBotEvent(
    {
      method: 'get_weather',
      params: {
        city: 'Moscow',
      },
    }
  )
  .then(data => {
    // Handle response
    console.log('response', data)
  })
  .then(({ type: method, handler: botx, payload: params }) => {
    // Handle response data type, payload
  })
  .catch(() => {
    // Do something on timeout
  })

Receive event from eXpress

SmartAppBridge.onRecieve(({ type, payload }) => {
  // This callback triggers when eXpress client send data without ref
})

Enable/Disable renaming event params from camelCase to snake_case and vice versa

  • Params are renamed from camelCase to snake_case and vice versa by default
  • Call after sending ready event
SmartAppBridge.disableRenameParams()
SmartAppBridge.enableRenameParams()

Enable/disable logging smart app events

SmartAppBridge.enableLogs()
SmartAppBridge.disableLogs()

Logging via bridge on mobile devices

  • log your data inside a smart app:
  import { Bridge as bridge } from '@unlimited/smartapp-bridge'

  const data: string | value = { logs: 'test' }
  bridge?.log?.(data)
  • Search in mobile logs by 'SmartApp Log' string
SmartAppBridge?.log?.(data)

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 85.4%
  • HTML 13.5%
  • JavaScript 1.1%