Skip to content

civictechdc/eligibility-blueprint

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Eligibility Blueprint

Demo here: https://kind-spence-14935a.netlify.com

Eligibility blueprint is an application for bootstrapping a "decision-tree" webform which asks users to answer a set of questions. Then, based on the answers to those questions, delivers a set of results.

Eligibilty Primitives:

  • questions
  • answers
  • results
  • decision tree (or "eligibility workflow")

An eligibility workflow is the set of relationships between questions and answers (which answers should lead to which questions) and the set of answers required to be considered eligible. For CFSA, results were a set of programs but they could just as easily be a single eligibility result or something else we haven't thought of. The functionality may serve any problem where a set of answers to a set of questions can be used to determine a set of results.

How to use

The eligibility blueprint is a project that came out of DC's Child and Family Services Agency (CFSA) Referral Prototype. The current set of questions and programs referenced in the Getting Started section below have been defined by CFSA. All that's required to create a new eligibility workflow is to define your own set of questions, programs and a decision tree.

Once this data is defined for the given use case, users should create a spreadsheet that is structured like the one created for CFSA.

Getting started

  • install node.js
  • Install nvm
# Clone this repository
$ git clone git@github.com:codefordc/eligibility-blueprint.git

# Go into the repository
$ cd eligibility-blueprint 

# Use the right version of node
$ nvm install

# Install dependencies
$ yarn install

# Run Tests
$ yarn test

# Run the app
$ yarn start

Configuration

Questions and programs data is configured via CSVs identified in .env.

There are 2 CSVs which should be referenced.

1. The Questions CSV

REACT_APP_QUESTIONS_CSV should point to a CSV with the following columns and values:

  • id: A question identifier, example: 1.
  • question: Question, example: "How many people live in your household?"
  • start: Boolean, true or false. There should only be one question for which this value is true.
  • questionType: 'boolean' for true / false ("yes" / "no") questions or 'categorical' for questions with multiple options (e.g. "toast", "bagel", "english muffin").
  • continueRules: Comma-separated ids of the next question to ask, dependent on the answer. In the case that the answer type is boolean, the first value identifies the next question to ask when the response is true and the second the identifier of the next question when the response is false.

2. The Program Eligibity Requirements CSV

REACT_APP_PROGRAMS_CSV should point to a CSV wit the following columns and values:

  • id: A program eligibility requirement identifier.
  • program: Human-readable program name.
  • question: A comma-separated list of question ids where a response is required to determine eligibility.
  • value: A comma-separated list of answer values to map to questions from the question column.

Each row in the programs CSV is a set of program eligibility requirements, not a program definition itself. A single program could be associated with multiple sets of program eligibility requirements. For example, with housing assistance, a person is eligible for assistance if they have a household size of 2 and income below $20,575 or they have a household size of 3 and income below $25,975.

CSV Examples

Technology

This project was bootstrapped with Create React App.

Below you will find some information on how to perform common tasks.
You can find the most recent version of this guide here.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published