Documentation

    Configuration Options

    You can customize the behavior of the Co-Browsing API Flutter SDK through configuration options.

    Setting Configuration

    Pass options when creating the UpscopeConfiguration:

    final config = UpscopeConfiguration(
      apiKey: 'YOUR_API_KEY',
      requireAuthorizationForSession: true,
      authorizationPromptTitle: 'Screen Sharing Request',
      authorizationPromptMessage: 'Allow {%agentName%|Support} to view your screen?',
      endOfSessionMessage: 'Thanks for using screen sharing!',
      translationsYes: 'Allow',
      translationsNo: 'Decline',
    );
    
    await Upscope.instance.initialize(config);
    

    Configuration Options

    Session Authorization

    OptionTypeDefaultDescription
    requireAuthorizationForSessionbooltrueRequire user permission before screen sharing starts.
    authorizationPromptTitleString?(Set through the admin interface)Custom title for the authorization dialog.
    authorizationPromptMessageString?(Set through the admin interface)Custom message for the authorization dialog. Supports placeholders.

    Message Placeholders

    The authorizationPromptMessage supports these placeholders:

    • {%agentName%|fallback} - Agent's name with a fallback if unavailable
    • {%currentDomain%} - App name

    Example:

    authorizationPromptMessage: '{%agentName%|Our support team} would like to view your screen',
    

    UI Display

    OptionTypeDefaultDescription
    showBannerbooltrueShow an in-app banner while a session is active.
    showTerminateButtonbooltrueShow a button in the banner to end the screen sharing session.
    endOfSessionMessageString?(Set through the admin interface)Message displayed when the session ends.
    stopSessionTextString?(Set through the admin interface)Custom text for the stop session button.

    Remote Control

    OptionTypeDefaultDescription
    allowRemoteClickbool?(Set through the admin interface)Allow agents to remotely tap on the screen.
    allowRemoteScrollbool?(Set through the admin interface)Allow agents to remotely scroll the screen.
    requireControlRequestbool?(Set through the admin interface)Require user approval before agents can use remote input.
    controlRequestTitleString?(Set through the admin interface)Custom title for the control request prompt.
    controlRequestMessageString?(Set through the admin interface)Custom message for the control request prompt.

    Lookup Code

    OptionTypeDefaultDescription
    enableLookupCodeOnShakebool?(Set through the admin interface)Show lookup code popup when device is shaken.
    lookupCodeKeyTitleString?(Set through the admin interface)Custom title for the shake detection alert.
    lookupCodeKeyMessageString?(Set through the admin interface)Custom message for shake alert. Supports {%lookupCode%} placeholder.

    Localization Strings

    OptionTypeDescription
    translationsYesString?Custom text for "Allow" button in authorization prompt.
    translationsNoString?Custom text for "Deny" button in authorization prompt.
    translationsOkString?Custom text for "OK" button.

    System Options

    OptionTypeDescription
    autoConnectboolAutomatically connect on initialization. Default: true (set through the admin interface).
    regionString?Server region for connections.

    Full Example

    final config = UpscopeConfiguration(
      apiKey: 'YOUR_API_KEY',
      requireAuthorizationForSession: true,
      autoConnect: true,
      authorizationPromptTitle: 'Screen Share',
      authorizationPromptMessage: '{%agentName%|Support} wants to help you',
      showBanner: true,
      showTerminateButton: true,
      endOfSessionMessage: 'Session ended. Thank you!',
      stopSessionText: 'End Session',
      allowRemoteClick: true,
      allowRemoteScroll: true,
      enableLookupCodeOnShake: true,
      lookupCodeKeyTitle: 'Your Code',
      lookupCodeKeyMessage: 'Share this code: {%lookupCode%}',
      translationsYes: 'Yes, share',
      translationsNo: 'No thanks',
      translationsOk: 'Got it',
      region: 'us-east',
    );
    
    await Upscope.instance.initialize(config);