Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Table Of Contents

...

#StepStatus
1Responsible prepares rough business analysis/reqs doc
COMPLETE Pierre Dane
2Get CHAI reviewCOMPLETE Vivek Agrawal
3Get Akros ReviewCOMPLETE Christina Riley
4Get Ona feedback

COMPLETE Craig Appl

5Responsible - 1 iteration for feedback

COMPLETE Pierre Dane

6Ona sign offCOMPLETE Craig Appl
7Ona tech spec scopingCOMPLETE  Craig Appl
8Ona LOE 
9Ona scheduling

Definitions

...

  • It can be in close proximity to a mosquito collection point, larval dipping site or a structure
  • It can be within or outside of an operational area
  • It can be a distinct thing next to a residential structure
  • Identifying PAOTs  is part of the Thai protocol and is currently done on hand-drawn maps
  • Dropping a point for or editing a potential area of Transmission should not be restricted by GPS proximity


Functional Requirements

  1. OVERVIEW: A user should be able to add an icon (TBD) to the Reveal Android map showing a Potential Area of Transmission (PAOT). 
  2. FORM FIELDS: The user should be able to add a comment to the PAOT form (not mandatory) - maximum string size tbc (2000 chars? this should be the same as other comment fields in Reveal) specify the type of PAOT from a drop-down (list to be provided - 'Pond, Cave, Forest) (Pedro Pagalday Olivares to confirm this please)
  3. FORM FIELDS:
    1. The comment field (task/form) should be editable Craig Appl - can you verify that each time this data is saved that a new form is submitted to the server (same data workflow as mosq collection point & larval dipping).
    2. The date that the PAOT was recorded should be recorded and displayed on the card view
    3. We should be able to see a historical view of the comments & dates recorded as a PAOT in the web UI & supersets.(low priority)
  4. REQUIREDNESS: It is not mandatory to add a PAOT to a focus
  5. LIFECYCLE: The PAOT will persist across subsequent FI, but should be able to be removed (set to inactive) I.e. they do not expire
  6. LIFECYCLE: The addition of a  POAT a  PAOT to a focus area will, in general, be a .once off task performed during the first visit
  7. USAGE: The PAOT data should be synced to the Reveal WebUI and be visible in the Web UI maps (high priority)
  8. USAGE: The PAOT data should be as a line listing reports (to be mocked up) (low priority) - the comment should display when clicking the POAT PAOT icon in the WebUI
  9. USAGE: The PAOT should be synced to Biophics in the same way that other tasks are (high priority) - this is where the BVBD will analyse the data
  10. PLANNING: The PAOT activity will not be part of a plan activity ←Changed this on 18 July | We will generate plan actions and goals to visit any existing PAOT and update the information in the system.
  11. TASK STATUS: The PAOT can be coulored yellow when it is created:
    1. Once selected and the comment field is filled out, the color will turn to green for status of 'Completed'.
  12. LINKAGE: One focus area can have multiple PAOTs
  13. LINKAGE: The PAOT is associated to a focus area and not explicitly to an Index Case. This linkage can be assumed through the 1:1 mapping of focus area and index case per plan. However, the PAOT is not necessarily related to the index or secondary cases in the focus i.e. it is a potential area of transmission, not THE potential area of transmission for the cases in the focus at that time.
  14. EDGE CASE: A PAOT is NEVER another type of structure, and if a structure is identified as a potential source then a PAOT should be added alongside the existing structure
    1. A potential issue raised is what happens with very large structures (Markets, football fields) as PAOT cannot be dropped on top of this - Vivek confirmed that this was discussed with BVBD and placing a pit next to the structure with a comment is sufficient

Software Specification

This section defines the software development that needs to take place in order to deliver this feature.

Assumptions

This section defines the assumptions required for this new feature.

  • Comments from Potential Areas of Transmission are plan specific. We will not transfer comments from one plan to the next.
  • Tasks for PAOTs need to be defined per plan. If a new plan is generated, we need to generate new tasks for existing PAOTs based on the actions that are defined in that plan.

Android Client

Assumptions

  • Tasks assigned to these points do not need to be displayed in the task list view. They are only required in the map view.

Development Required

  •  Update the register structure form to include a new Potential Area of Transmission (Data dictionary link)
  •  Add a PAOT form in English and Thai (Data dictionary link)
    •  If the status of the PAOT changes from "Active" to "Inactive" the post save action will make this point inactive in the location and sync the updated location to the server
  •  Add a PAOT client to the EC data model
  •  Add a card view to display the new PAOT

This card view should have the following attributes:
Title: Potential Area of Transmission
Icon: Should be the icon of the area of transmission
Field 1: "Last Updated Date" (form variable name = lastUpdatedDate)
Button with Label: Edit PAOT Details
Button Action: Open a form to edit the existing information that has been captured. We need to retain a copy of all comments and allow the user to add to the comments Allow the user to edit comments 

  •  Add a new icon type to the Android client and support the colour coding as defined in the Task business logic and colour coding section of this document
  •  Add the ability to edit the existing form in the system when the user completes it saving the comment history and updating the lastUpdatedDate field each time the form is edited.

Server and Web UI

Assumptions

  • These points need to display in the map view across plan actions so that users are able to see PAOTs plan action that's selected in the right menu

Development Required

  •  Update the ETL process to extract these new forms from the OpenSRP server and post them to the data warehouse
  •  Add a new icon type to the Web UI and support color coding of these points as defined in the map view
  •  Update the process for generating tasks for new plans to include the Potential Areas of Transmission task generation on existing PAOTs that have properties.status=Active
  •  (Lower Priority) Add the ability to view PAOTs across plan action goals so that users can see the relationship between each plan action and PAOTs
  •  (Lower Priority) Display comments in the pop-up when a user clicks a PAOT in the map view

Plan Action and Goal Templates

We need to add the following plan action and goal templates for these PAOT

Code Block
languagejs
titleSample POAT Plan Goal
linenumberstrue
{
  "id": "PAOT_goal",
  "description": "Update Potential Areas of Transmission",
  "priority": "medium-priority",
  "target": [
    {
      "measure": "Percent of PAOT updated",
      "detail": {
        "detailQuantity": {
          "value": 100,
          "comparator": ">=",
          "unit": "percent"
        }
      },
      "due": "${now():toNumber():plus(864000000):format("yyyy-MM-dd")}"
    }
  ]
}


Code Block
languagejs
titleSample POAT Plan Action
linenumberstrue
{
  "identifier": "${UUID()}",
  "prefix": 7,
  "title": "Potential Area(s) of Transmission",
  "description": "Update Potential Areas of Transmission",
  "code": "PAOT",
  "timingPeriod": {
	"start": "${now():format("yyyy-MM-dd", "GMT")}",
	"end": "${now():toNumber():plus(864000000):format("yyyy-MM-dd")}"
  },
  "reason": "Investigation",
  "goalId": "PAOT_goal",
  "subjectCodableConcept": {
	"text": "PAOT"
  },
  "taskTemplate": "PAOT"
}


Task business logic and colour coding

Form Name(s): PAOT
Intervention Unit: Location with type: PAOT

Status Colour Coding

ColorBusinessStatusLogic
GreenComplete

The form has been filled.

Calculation: task.businessStatus = “Complete”

YellowNot Visited

The form has not been completed for this task.

Calculation: task.businessStatus = “Not Visited”

Task Template

PAOT Tasks need the following template (Note that this impacts the automatic plan generation)

Code Block
languagejs
titleSample POAT Task Template
linenumberstrue
{
  "identifier": "${UUID()}",
  "planIdentifier": "${planIdentifier}",
  "groupIdentifier": "${location.properties.parentId}",
  "status": "Ready",
  "businessStatus": "Not Visited",
  "priority": 3,
  "code": "${planActionCode}",
  "description": "${planActionDescription}",
  "focus": "${planActionIdentifier}",
  "for": "${location.id}",
  "executionStartDate": "${planActionTimingPeriodStart}",
  "executionEndDate": "${planActionTimingPeriodEnd}",
  "owner": "${taskOwner}",
  "note": null
}

Icon

Below is a sample icon

Image Added

Mock-Ups

 

Adding a PAOT                                              PAOT Form                                            Card View

...

  • Android - Add structure form
  • Android - Maps - Add a new icon with colour coding
  • Android - Maps - Add a card view when the user taps the POATPAOT
  • Android - New form to collect comments
  • Web - Maps - Display these new icons in the web view
  • Web - Maps - Display comments when the user taps on the POAT PAOT in the map (Low priority)

...

  1. This feature has been described as a Potential Source of Infection (POI) and a Potential Source of Transmission- which is correct?
    1. Confirmed by Vivek Agrawal as Potential Area of Transmission (PAOT)
  2. Was this requirement mentioned during the initial first visit? To confirm with Pedro

Workflow

2.3.0: Workflow

Click '+' button in bottom left when in an area. See the following:

Image Added

Select PAOT option and navigate on map to drop point in the PAOT:

Image Added


Press save. The icon is autoselected and you remain with that area in view:

Image Added


Tap PAOT icon. The form appears:

Image Added


Select Active or Inactive and complete. The questions do not change based on the status selected:

Image Added

Select save. The icon is now green.

Image Added

Test Case

#

Step

Pass / Fail

Comment

1




2




3




4




5




6




7




8




Additional tester comments:







...