# Interacting with the user

The mission app is available on the tablet and is used to start missions as well as interact with the mission throughout the duration of its execution.

# Main display Widgets

The Main Display widgets are available on top of the mission map. You can configure the elements as needed at anytime.

Element Description
Mission Briefing Opens the briefing page (see below)
Mission Dispatch Briefing Opens the briefing page (see below)
User Actions Generic commands which the user may also bind to a button on their controller and activate without the tablet open.
Hover Target Display Provides guidance cross-hair UI to a specific location (target)
Message Provides text for the user to guide them at this stage of the mission
Progress Bar Provides status information regarding the current objective or overall mission
Objective Title Provides information regarding the current main objective
Modal Dialog Requests the user to make a choice

Each widget is covered in the test program below.

To start you can use set_message.

{"set_message": "hello world"}

And this message will be visible at the bottom of the mission app.

# Briefing & Dispatch Widgets

These widgets are available for the dispatch and briefing pages. The briefing is static and defined with the mission, while the dispatch is dynamic and may be changed at anytime.

Element Description
#comment human-readable description, no effect
title Display large heading text
text Display text with various formatting
textbox Allow the user to type free-form text
buttonbar Create a row of buttons
buttonbar.button Create clickable button (with select_condition)
link Create clickable link
image Draw an image
describe_icon Draw a small image with text to the right of it
iframe Display an IFrame
slider Display an slider which the user may use to pick from a range of values
progressbar Display a range of values

Each widget has show_condition and disabled_condition:

  • show_condition: Optional. QUERY which determines if the element should be visible.
  • disabled_condition: Optional. QUERY which determines if the element should be non-interactive and visibly disabled.
  • select_condition: Optional. QUERY which determines if the element should be visually selected. (buttonbar.button only)

# Map Widgets

Map widgets enable you to place elements onto the mission map (and also available on DMAP/NAVD on the aircraft MFDs).

You can add points with icon and/or text, and draw lines. You can also draw a precise range circle around a point.

Examples:


{"copy_location":{"bearing":330,"dist":500},"to":"P1"},
{"copy_location":{"bearing":30,"dist":500},"to":"P2"},
{"copy_location":{"bearing":120,"dist":500},"to":"P3"},
{"copy_location":{"bearing":240,"dist":500},"to":"P4"},
{"set_map":{"add":{"line":{ "points":["P1","P2","P3","P4", "P1"], "stroke":{"color":"#4287f5", "width":4}}}}},

{"set_map":{"add":{"point":{"location":"P1","text":"waypoint text"}}}},
{"set_map":{"add":{"point":{"location":"P4","icon":"ki_helipad"}}}},

You may monitor the user's map selection by looking at the location $MISSION_SELECTED_POI_LOCATION and L:MISSION_SELECTED_POI_TYPE (zero if not selected).

# Widget Test Program

This program has an example of each of the widgets.

{
  "title": "Widget Test Program",
  "briefing": [
    {"title": "Briefing Title"},
    {"text": "pagraph text"},
    {"text": "pagraph text with params {0} {1}", "params":[99, 100]},
    {"text": "red text", "color": "red"},
    {"text": "centered text", "align": "center"},
    {"text": "Text input: (value: {0})", "params": [{"local": "my_textbox"}]},
    {"textbox": "my_textbox"},
    
    {"text": "Button bar (button clicked count={0})", "params":[{"local":"test_local"}]},
    {"buttonbar":[
      {"title":"add", "commands":[
        {"set": {"local":"test_local"}, "value": {"add":[{"local":"test_local"}, 1]}}
      ]},
      {"title":"subtract", "commands":[
        {"set": {"local":"test_local"}, "value": {"add":[{"local":"test_local"}, -1]}}
      ]},
      {
        "title":"my button (with conditions)", 
        "commands":[
          {"set": {"local":"test_local"}, "value": {"add":[{"local":"test_local"}, 1]}}
        ],
        "show_condition":{"require":{"local":"test_local"}, "gt":0},
        "select_condition":{"require":{"local":"test_local"}, "eq":2},
        "disabled_condition":{"require":{"local":"test_local"}, "eq":3}
      }
    ]},
    
    {"link":"my link", "commands": [
      {"set": {"local":"test_local"}, "value": {"add":[{"local":"test_local"}, 1]}}
    ]},
    
    {"image": "https://www.hypeperformancegroup.com/cdn/shop/files/HPG_Solid_Transparent_180x.png"},
    
    {"describe_icon": "fire_station", "description": "icon description here"},
    
    {"iframe": "https://davux.com/docs", "height": 400},

    {"slider":{ "min":0, "max":100, "var":["L:TEST","number"] }},

    {"progressbar":{ "min":0, "max":100, "color":"red", "var":["L:TEST","number"] }},

    {"#comment":"you may add comments as needed"}
  ],
  "objectives": [
    {
      "title": "Done",
      "commands": [
        {"set": {"local":"test_local"}, "value":0},
        {"set":{"var":["L:TEST","number"]},"value":45},
        {"set_modal":{}},
                
        {"create_user_action": {
          "id": "user_action_1", 
          "title": "User Action 1",
          "click_commands": [ {"destroy_user_action":"user_action_1"} ] 
        }},
        {"create_user_action": {
          "id": "user_action_2", 
          "title": "User Action 2",
          "click_commands": [ {"destroy_user_action":"user_action_2"} ] 
        }},
        {"create_user_action": {
          "id": "user_action_3", 
          "title": "User Action 3",
          "click_commands": [ {"destroy_user_action":"user_action_3"} ] 
        }},
        {"create_user_action": {
          "id": "user_action_3", 
          "title": "User Action 4",
          "click_commands": [ {"destroy_user_action":"user_action_4"} ] 
        }},
        {"create_user_action": {
          "id": "user_action_5", 
          "title": "User Action 5",
          "click_commands": [ {"destroy_user_action":"user_action_5"} ] 
        }},
        {"create_user_action": {
          "id": "user_action_6", 
          "title": "User Action 6",
          "click_commands": [ {"destroy_user_action":"user_action_6"} ] 
        }},
        
        {"set_hover_display":{"target":"$USER","range":0.1}},
        
        {"set_message": "This is the user message area, the primary way to give insturctions without digging into the dispatch or briefing"},
        {"set_objective_title":"Main Objective Directive"},
   
        {"set_progressbar":{"min":0,"max":100,"var":["L:TEST","number"], "color":"green"}},
        
        {"set_dispatch":[
          {"text":"Example dispatch"}
        ]},
        
        {"set_modal": {
          "title": "Modal Dialog", 
          "text": "Description of the modal dialog and the actions below.<br /><br /> The modal dialog may be used to request a choice from the user, without them needing to interact with the breifing or dispatch.", 
          "options": [
            {"text": "Option 1", "style": "primary", "commands": [
              {"#comment": "use a sleep 0 here to make sure button with empty list still executes"},
              {"sleep": 0}
            ]},
            {"text": "Option 2", "style": "secondary", "commands": [
              {"#comment": "use a sleep 0 here to make sure button with empty list still executes"},
              {"sleep": 0}
            ]},
            {"text": "Option 3", "style": "danger", "commands": [
              {"#comment": "use a sleep 0 here to make sure button with empty list still executes"},
              {"sleep": 0}
            ]},
            {"text": "Option 4", "style": "subtle", "commands": [
              {"#comment": "use a sleep 0 here to make sure button with empty list still executes"},
              {"sleep": 0}
            ]},
            {"text": "Option 5", "style": "", "commands": [
              {"#comment": "use a sleep 0 here to make sure button with empty list still executes"},
              {"sleep": 0}
            ]}
          ]
        }},
        
        {"copy_location":{"bearing":330,"dist":500},"to":"P1"},
        {"copy_location":{"bearing":30,"dist":500},"to":"P2"},
        {"copy_location":{"bearing":120,"dist":500},"to":"P3"},
        {"copy_location":{"bearing":240,"dist":500},"to":"P4"},
		    {"set_map":{"add":{"line":{ "points":["P1","P2","P3","P4", "P1"], "stroke":{"color":"#4287f5", "width":4}}}}},
        
        {"set_map":{"add":{"point":{"location":"P1","text":"waypoint text"}}}},
        {"set_map":{"add":{"point":{"location":"P4","icon":"fire_station"}}}},
        
        {"sleep": "forever"}
      ]
    }
  ],
  "icons": {
    "fire_station": ""
  }
  
}