npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

dxp-questions-ui

v0.1.19

Published

The `dxp-questions-ui` library renders questions and answers that are provided by the Daxko Operations API.

Downloads

42

Readme

Daxko Questions UI Library

Build Status npm

The dxp-questions-ui library renders questions and answers that are provided by the Daxko Operations API.

Live Demo (See docs directory)

Feel free to use and submit issues and pull requests!

Installation

  • npm install dxp-questions-ui
  • Download latest release from Github
  • <script src="https://assets.daxko.com/dxp-questions-ui/lib/v0.1.13/dxp-questions-min.js"></script>

Development

  • Install node
  • npm install -g webpack if you don't have webpack installed already
  • npm install
  • npm start

This will rebuild the dist/dxp-questions.js file whenever changes are made.

To test the changes:

Usage

Required libraries that need to be included before including dxp-questions-min.js. See example/index.html for example of how to use.

<!-- css for pickadate -->
<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/pickadate.js/3.5.6/compressed/themes/default.date.css">
<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/pickadate.js/3.5.6/compressed/themes/default.css">

<!-- jquery -->
<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<!-- pickadate calendar -->
<script src="//cdnjs.cloudflare.com/ajax/libs/pickadate.js/3.5.6/picker.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/pickadate.js/3.5.6/compressed/picker.date.js"></script>
<!-- masked input plugin -->
<script src="//cdnjs.cloudflare.com/ajax/libs/jquery.mask/1.14.0/jquery.mask.min.js"></script>

<!-- dxp-questions ui library -->
<script src="https://assets.daxko.com/dxp-questions-ui/lib/v0.1.13/dxp-questions-min.js"></script>

Question rendering examples

Address

JSON

{
  "type": "address",
  "title": "Home Address",
  "description": "This is where your t-shirt will be shipped to.",
  "required": true,
  "read_only": false,
  "ca_provinces": [{
      "id": "AB",
      "name": "Alberta"
    },
    {
      "id": "BC",
      "name": "British Columbia"
    },
    {
      "id": "MB",
      "name": "Manitoba"
    },
    {
      "id": "NB",
      "name": "New Brunswick"
    },
    {
      "id": "NL",
      "name": "Newfoundland and Labrador"
    },
    {
      "id": "NT",
      "name": "Northwest Territories"
    },
    {
      "id": "NS",
      "name": "Nova Scotia"
    },
    {
      "id": "NU",
      "name": "Nunavut"
    },
    {
      "id": "ON",
      "name": "Ontario"
    },
    {
      "id": "PE",
      "name": "Prince Edward Island"
    },
    {
      "id": "QC",
      "name": "Quebec"
    },
    {
      "id": "SK",
      "name": "Saskatchewan"
    },
    {
      "id": "YT",
      "name": "Yukon"
    }
  ],
  "countries": [{
      "id": "AF",
      "name": "Afghanistan"
    },
    {
      "id": "AL",
      "name": "Albania"
    },
    {
      "id": "DZ",
      "name": "Algeria"
    },
    {
      "id": "AS",
      "name": "American Samoa"
    },
    {
      "id": "AD",
      "name": "Andorra"
    },
    {
      "id": "AO",
      "name": "Angola"
    },
    {
      "id": "AI",
      "name": "Anguilla"
    },
    {
      "id": "AQ",
      "name": "Antarctica"
    },
    {
      "id": "AG",
      "name": "Antigua And Barbuda"
    },
    {
      "id": "AR",
      "name": "Argentina"
    },
    {
      "id": "AM",
      "name": "Armenia"
    },
    {
      "id": "AW",
      "name": "Aruba"
    },
    {
      "id": "AU",
      "name": "Australia"
    },
    {
      "id": "AT",
      "name": "Austria"
    },
    {
      "id": "AZ",
      "name": "Azerbaijan"
    },
    {
      "id": "BS",
      "name": "Bahamas"
    },
    {
      "id": "BH",
      "name": "Bahrain"
    },
    {
      "id": "BD",
      "name": "Bangladesh"
    },
    {
      "id": "BB",
      "name": "Barbados"
    },
    {
      "id": "BY",
      "name": "Belarus"
    },
    {
      "id": "BE",
      "name": "Belgium"
    },
    {
      "id": "BZ",
      "name": "Belize"
    },
    {
      "id": "BJ",
      "name": "Benin"
    },
    {
      "id": "BM",
      "name": "Bermuda"
    },
    {
      "id": "BT",
      "name": "Bhutan"
    },
    {
      "id": "BO",
      "name": "Bolivia"
    },
    {
      "id": "BA",
      "name": "Bosnia And Herzegowina"
    },
    {
      "id": "BW",
      "name": "Botswana"
    },
    {
      "id": "BV",
      "name": "Bouvet Island"
    },
    {
      "id": "BR",
      "name": "Brazil"
    },
    {
      "id": "IO",
      "name": "British Indian Ocean Territory"
    },
    {
      "id": "BN",
      "name": "Brunei Darussalam"
    },
    {
      "id": "BG",
      "name": "Bulgaria"
    },
    {
      "id": "BF",
      "name": "Burkina Faso"
    },
    {
      "id": "BI",
      "name": "Burundi"
    },
    {
      "id": "KH",
      "name": "Cambodia"
    },
    {
      "id": "CM",
      "name": "Cameroon"
    },
    {
      "id": "CA",
      "name": "Canada"
    },
    {
      "id": "CV",
      "name": "Cape Verde"
    },
    {
      "id": "KY",
      "name": "Cayman Islands"
    },
    {
      "id": "CF",
      "name": "Central African Republic"
    },
    {
      "id": "TD",
      "name": "Chad"
    },
    {
      "id": "CL",
      "name": "Chile"
    },
    {
      "id": "CN",
      "name": "China"
    },
    {
      "id": "CX",
      "name": "Christmas Island"
    },
    {
      "id": "CC",
      "name": "Cocos (Keeling) Islands"
    },
    {
      "id": "CO",
      "name": "Colombia"
    },
    {
      "id": "KM",
      "name": "Comoros"
    },
    {
      "id": "CG",
      "name": "Congo"
    },
    {
      "id": "CD",
      "name": "Congo, The Democratic Republic Of The"
    },
    {
      "id": "CK",
      "name": "Cook Islands"
    },
    {
      "id": "CR",
      "name": "Costa Rica"
    },
    {
      "id": "CI",
      "name": "Cote D'ivoire"
    },
    {
      "id": "HR",
      "name": "Croatia (Local Name: Hrvatska)"
    },
    {
      "id": "CU",
      "name": "Cuba"
    },
    {
      "id": "CY",
      "name": "Cyprus"
    },
    {
      "id": "CZ",
      "name": "Czech Republic"
    },
    {
      "id": "DK",
      "name": "Denmark"
    },
    {
      "id": "DJ",
      "name": "Djibouti"
    },
    {
      "id": "DM",
      "name": "Dominica"
    },
    {
      "id": "DO",
      "name": "Dominican Republic"
    },
    {
      "id": "TP",
      "name": "East Timor"
    },
    {
      "id": "EC",
      "name": "Ecuador"
    },
    {
      "id": "EG",
      "name": "Egypt"
    },
    {
      "id": "SV",
      "name": "El Salvador"
    },
    {
      "id": "GQ",
      "name": "Equatorial Guinea"
    },
    {
      "id": "ER",
      "name": "Eritrea"
    },
    {
      "id": "EE",
      "name": "Estonia"
    },
    {
      "id": "ET",
      "name": "Ethiopia"
    },
    {
      "id": "FK",
      "name": "Falkland Islands (Malvinas)"
    },
    {
      "id": "FO",
      "name": "Faroe Islands"
    },
    {
      "id": "FJ",
      "name": "Fiji"
    },
    {
      "id": "FI",
      "name": "Finland"
    },
    {
      "id": "FR",
      "name": "France"
    },
    {
      "id": "FX",
      "name": "France, Metropolitan"
    },
    {
      "id": "GF",
      "name": "French Guiana"
    },
    {
      "id": "PF",
      "name": "French Polynesia"
    },
    {
      "id": "TF",
      "name": "French Southern Territories"
    },
    {
      "id": "GA",
      "name": "Gabon"
    },
    {
      "id": "GM",
      "name": "Gambia"
    },
    {
      "id": "GE",
      "name": "Georgia"
    },
    {
      "id": "DE",
      "name": "Germany"
    },
    {
      "id": "GH",
      "name": "Ghana"
    },
    {
      "id": "GI",
      "name": "Gibraltar"
    },
    {
      "id": "GR",
      "name": "Greece"
    },
    {
      "id": "GL",
      "name": "Greenland"
    },
    {
      "id": "GD",
      "name": "Grenada"
    },
    {
      "id": "GP",
      "name": "Guadeloupe"
    },
    {
      "id": "GU",
      "name": "Guam"
    },
    {
      "id": "GT",
      "name": "Guatemala"
    },
    {
      "id": "GN",
      "name": "Guinea"
    },
    {
      "id": "GW",
      "name": "Guinea-bissau"
    },
    {
      "id": "GY",
      "name": "Guyana"
    },
    {
      "id": "HT",
      "name": "Haiti"
    },
    {
      "id": "HM",
      "name": "Heard And McDonald Islands"
    },
    {
      "id": "VA",
      "name": "Holy See (Vatican City State)"
    },
    {
      "id": "HN",
      "name": "Honduras"
    },
    {
      "id": "HK",
      "name": "Hong Kong"
    },
    {
      "id": "HU",
      "name": "Hungary"
    },
    {
      "id": "IS",
      "name": "Iceland"
    },
    {
      "id": "IN",
      "name": "India"
    },
    {
      "id": "ID",
      "name": "Indonesia"
    },
    {
      "id": "IR",
      "name": "Iran (Islamic Republic Of)"
    },
    {
      "id": "IQ",
      "name": "Iraq"
    },
    {
      "id": "IE",
      "name": "Ireland"
    },
    {
      "id": "IL",
      "name": "Israel"
    },
    {
      "id": "IT",
      "name": "Italy"
    },
    {
      "id": "JM",
      "name": "Jamaica"
    },
    {
      "id": "JP",
      "name": "Japan"
    },
    {
      "id": "JO",
      "name": "Jordan"
    },
    {
      "id": "KZ",
      "name": "Kazakhstan"
    },
    {
      "id": "KE",
      "name": "Kenya"
    },
    {
      "id": "KI",
      "name": "Kiribati"
    },
    {
      "id": "KP",
      "name": "Korea, Democratic People's Republic Of"
    },
    {
      "id": "KR",
      "name": "Korea, Republic Of"
    },
    {
      "id": "KW",
      "name": "Kuwait"
    },
    {
      "id": "KG",
      "name": "Kyrgyzstan"
    },
    {
      "id": "LA",
      "name": "Lao People's Democratic Republic"
    },
    {
      "id": "LV",
      "name": "Latvia"
    },
    {
      "id": "LB",
      "name": "Lebanon"
    },
    {
      "id": "LS",
      "name": "Lesotho"
    },
    {
      "id": "LR",
      "name": "Liberia"
    },
    {
      "id": "LY",
      "name": "Libyan Arab Jamahiriya"
    },
    {
      "id": "LI",
      "name": "Liechtenstein"
    },
    {
      "id": "LT",
      "name": "Lithuania"
    },
    {
      "id": "LU",
      "name": "Luxembourg"
    },
    {
      "id": "MO",
      "name": "Macau"
    },
    {
      "id": "MK",
      "name": "Macedonia, Former Yugoslav Republic Of"
    },
    {
      "id": "MG",
      "name": "Madagascar"
    },
    {
      "id": "MW",
      "name": "Malawi"
    },
    {
      "id": "MY",
      "name": "Malaysia"
    },
    {
      "id": "MV",
      "name": "Maldives"
    },
    {
      "id": "ML",
      "name": "Mali"
    },
    {
      "id": "MT",
      "name": "Malta"
    },
    {
      "id": "MH",
      "name": "Marshall Islands"
    },
    {
      "id": "MQ",
      "name": "Martinique"
    },
    {
      "id": "MR",
      "name": "Mauritania"
    },
    {
      "id": "MU",
      "name": "Mauritius"
    },
    {
      "id": "YT",
      "name": "Mayotte"
    },
    {
      "id": "MX",
      "name": "Mexico"
    },
    {
      "id": "FM",
      "name": "Micronesia, Federated States Of"
    },
    {
      "id": "MD",
      "name": "Moldova, Republic Of"
    },
    {
      "id": "MC",
      "name": "Monaco"
    },
    {
      "id": "MN",
      "name": "Mongolia"
    },
    {
      "id": "MS",
      "name": "Montserrat"
    },
    {
      "id": "MA",
      "name": "Morocco"
    },
    {
      "id": "MZ",
      "name": "Mozambique"
    },
    {
      "id": "MM",
      "name": "Myanmar"
    },
    {
      "id": "NA",
      "name": "Namibia"
    },
    {
      "id": "NR",
      "name": "Nauru"
    },
    {
      "id": "NP",
      "name": "Nepal"
    },
    {
      "id": "NL",
      "name": "Netherlands"
    },
    {
      "id": "AN",
      "name": "Netherlands Antilles"
    },
    {
      "id": "NC",
      "name": "New Caledonia"
    },
    {
      "id": "NZ",
      "name": "New Zealand"
    },
    {
      "id": "NI",
      "name": "Nicaragua"
    },
    {
      "id": "NE",
      "name": "Niger"
    },
    {
      "id": "NG",
      "name": "Nigeria"
    },
    {
      "id": "NU",
      "name": "Niue"
    },
    {
      "id": "NF",
      "name": "Norfolk Island"
    },
    {
      "id": "MP",
      "name": "Northern Mariana Islands"
    },
    {
      "id": "NO",
      "name": "Norway"
    },
    {
      "id": "OM",
      "name": "Oman"
    },
    {
      "id": "PK",
      "name": "Pakistan"
    },
    {
      "id": "PW",
      "name": "Palau"
    },
    {
      "id": "PA",
      "name": "Panama"
    },
    {
      "id": "PG",
      "name": "Papua New Guinea"
    },
    {
      "id": "PY",
      "name": "Paraguay"
    },
    {
      "id": "PE",
      "name": "Peru"
    },
    {
      "id": "PH",
      "name": "Philippines"
    },
    {
      "id": "PN",
      "name": "Pitcairn"
    },
    {
      "id": "PL",
      "name": "Poland"
    },
    {
      "id": "PT",
      "name": "Portugal"
    },
    {
      "id": "PR",
      "name": "Puerto Rico"
    },
    {
      "id": "QA",
      "name": "Qatar"
    },
    {
      "id": "RE",
      "name": "Reunion"
    },
    {
      "id": "RO",
      "name": "Romania"
    },
    {
      "id": "RU",
      "name": "Russian Federation"
    },
    {
      "id": "RW",
      "name": "Rwanda"
    },
    {
      "id": "KN",
      "name": "Saint Kitts And Nevis"
    },
    {
      "id": "LC",
      "name": "Saint Lucia"
    },
    {
      "id": "VC",
      "name": "Saint Vincent And The Grenadines"
    },
    {
      "id": "WS",
      "name": "Samoa"
    },
    {
      "id": "SM",
      "name": "San Marino"
    },
    {
      "id": "ST",
      "name": "Sao Tome And Principe"
    },
    {
      "id": "SA",
      "name": "Saudi Arabia"
    },
    {
      "id": "SN",
      "name": "Senegal"
    },
    {
      "id": "SC",
      "name": "Seychelles"
    },
    {
      "id": "SL",
      "name": "Sierra Leone"
    },
    {
      "id": "SG",
      "name": "Singapore"
    },
    {
      "id": "SK",
      "name": "Slovakia (Slovak Republic)"
    },
    {
      "id": "SI",
      "name": "Slovenia"
    },
    {
      "id": "SB",
      "name": "Solomon Islands"
    },
    {
      "id": "SO",
      "name": "Somalia"
    },
    {
      "id": "ZA",
      "name": "South Africa"
    },
    {
      "id": "GS",
      "name": "South Georgia/South Sandwich Islands"
    },
    {
      "id": "ES",
      "name": "Spain"
    },
    {
      "id": "LK",
      "name": "Sri Lanka"
    },
    {
      "id": "SH",
      "name": "St. Helena"
    },
    {
      "id": "PM",
      "name": "St. Pierre And Miquelon"
    },
    {
      "id": "SD",
      "name": "Sudan"
    },
    {
      "id": "SR",
      "name": "Suriname"
    },
    {
      "id": "SJ",
      "name": "Svalbard And Jan Mayen Islands"
    },
    {
      "id": "SZ",
      "name": "Swaziland"
    },
    {
      "id": "SE",
      "name": "Sweden"
    },
    {
      "id": "CH",
      "name": "Switzerland"
    },
    {
      "id": "SY",
      "name": "Syrian Arab Republic"
    },
    {
      "id": "TW",
      "name": "Taiwan, Province Of China"
    },
    {
      "id": "TJ",
      "name": "Tajikistan"
    },
    {
      "id": "TZ",
      "name": "Tanzania, United Republic Of"
    },
    {
      "id": "TH",
      "name": "Thailand"
    },
    {
      "id": "TG",
      "name": "Togo"
    },
    {
      "id": "TK",
      "name": "Tokelau"
    },
    {
      "id": "TO",
      "name": "Tonga"
    },
    {
      "id": "TT",
      "name": "Trinidad And Tobago"
    },
    {
      "id": "TN",
      "name": "Tunisia"
    },
    {
      "id": "TR",
      "name": "Turkey"
    },
    {
      "id": "TM",
      "name": "Turkmenistan"
    },
    {
      "id": "TC",
      "name": "Turks And Caicos Islands"
    },
    {
      "id": "TV",
      "name": "Tuvalu"
    },
    {
      "id": "UG",
      "name": "Uganda"
    },
    {
      "id": "UA",
      "name": "Ukraine"
    },
    {
      "id": "AE",
      "name": "United Arab Emirates"
    },
    {
      "id": "GB",
      "name": "United Kingdom"
    },
    {
      "id": "UM",
      "name": "United States Minor Outlying Islands"
    },
    {
      "id": "US",
      "name": "United States"
    },
    {
      "id": "UY",
      "name": "Uruguay"
    },
    {
      "id": "UZ",
      "name": "Uzbekistan"
    },
    {
      "id": "VU",
      "name": "Vanuatu"
    },
    {
      "id": "VE",
      "name": "Venezuela"
    },
    {
      "id": "VN",
      "name": "Vietnam"
    },
    {
      "id": "VG",
      "name": "Virgin Islands (British)"
    },
    {
      "id": "VI",
      "name": "Virgin Islands (U.S.)"
    },
    {
      "id": "WF",
      "name": "Wallis And Futuna Islands"
    },
    {
      "id": "EH",
      "name": "Western Sahara"
    },
    {
      "id": "YE",
      "name": "Yemen"
    },
    {
      "id": "YU",
      "name": "Yugoslavia"
    },
    {
      "id": "ZM",
      "name": "Zambia"
    },
    {
      "id": "ZW",
      "name": "Zimbabwe"
    }
  ],
  "intl": true
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
    <label class="dxp-question-title">
        Home Address
        <span class="dxp-required-indicator">*</span>
    </label>
    <small class="dxp-question-help-text">This is where your t-shirt will be shipped to.</small>
    <div class="dxp-question-body">
        <div class="dxp-name-question">
            <div class="dxp-address-line1" title="is required.">
                <label>Address Line 1</label>
                <input type="text" maxlength="50" class="dxp-field-error" value="">
                <div class="dxp-error-description">is required.</div>
            </div>
            <div class="dxp-address-line2">
                <label>Address Line 2</label>
                <input type="text" maxlength="50" class="" value="">
            </div>
            <div class="dxp-address-city" title="is required.">
                <label>City</label>
                <input type="text" maxlength="50" class="dxp-field-error" value="">
                <div class="dxp-error-description">is required.</div>
            </div>
            <div class="dxp-address-state">
                <label>Province/Region</label>
                <input type="text" maxlength="50" class="" value="AL">
            </div>
            <div class="dxp-address-zip" title="is required.">
                <label>Postal Code</label>
                <input type="text" placeholder="" maxlength="15" class="dxp-field-error" value="">
                <div class="dxp-error-description">is required.</div>
            </div>
            <div class="dxp-address-country">
                <label>Country</label>
                <select class="">
                    <option></option>
                    <option value="AF">Afghanistan</option>
                    <option value="AL">Albania</option>
                    <option value="DZ">Algeria</option>
                    <option value="AS">American Samoa</option>
                    <option value="AD">Andorra</option>
                    <option value="AO">Angola</option>
                    <option value="AI">Anguilla</option>
                    <option value="AQ">Antarctica</option>
                    <option value="AG">Antigua And Barbuda</option>
                    <option value="AR">Argentina</option>
                    <option value="AM">Armenia</option>
                    <option value="AW">Aruba</option>
                    <option value="AU">Australia</option>
                    <option value="AT">Austria</option>
                    <option value="AZ">Azerbaijan</option>
                    <option value="BS">Bahamas</option>
                    <option value="BH">Bahrain</option>
                    <option value="BD">Bangladesh</option>
                    <option value="BB">Barbados</option>
                    <option value="BY">Belarus</option>
                    <option value="BE">Belgium</option>
                    <option value="BZ">Belize</option>
                    <option value="BJ">Benin</option>
                    <option value="BM">Bermuda</option>
                    <option value="BT">Bhutan</option>
                    <option value="BO">Bolivia</option>
                    <option value="BA">Bosnia And Herzegowina</option>
                    <option value="BW">Botswana</option>
                    <option value="BV">Bouvet Island</option>
                    <option value="BR">Brazil</option>
                    <option value="IO">British Indian Ocean Territory</option>
                    <option value="BN">Brunei Darussalam</option>
                    <option value="BG">Bulgaria</option>
                    <option value="BF">Burkina Faso</option>
                    <option value="BI">Burundi</option>
                    <option value="KH">Cambodia</option>
                    <option value="CM">Cameroon</option>
                    <option value="CA">Canada</option>
                    <option value="CV">Cape Verde</option>
                    <option value="KY">Cayman Islands</option>
                    <option value="CF">Central African Republic</option>
                    <option value="TD">Chad</option>
                    <option value="CL">Chile</option>
                    <option value="CN">China</option>
                    <option value="CX">Christmas Island</option>
                    <option value="CC">Cocos (Keeling) Islands</option>
                    <option value="CO">Colombia</option>
                    <option value="KM">Comoros</option>
                    <option value="CG">Congo</option>
                    <option value="CD">Congo, The Democratic Republic Of The</option>
                    <option value="CK">Cook Islands</option>
                    <option value="CR">Costa Rica</option>
                    <option value="CI">Cote D'ivoire</option>
                    <option value="HR">Croatia (Local Name: Hrvatska)</option>
                    <option value="CU">Cuba</option>
                    <option value="CY">Cyprus</option>
                    <option value="CZ">Czech Republic</option>
                    <option value="DK">Denmark</option>
                    <option value="DJ">Djibouti</option>
                    <option value="DM">Dominica</option>
                    <option value="DO">Dominican Republic</option>
                    <option value="TP">East Timor</option>
                    <option value="EC">Ecuador</option>
                    <option value="EG">Egypt</option>
                    <option value="SV">El Salvador</option>
                    <option value="GQ">Equatorial Guinea</option>
                    <option value="ER">Eritrea</option>
                    <option value="EE">Estonia</option>
                    <option value="ET">Ethiopia</option>
                    <option value="FK">Falkland Islands (Malvinas)</option>
                    <option value="FO">Faroe Islands</option>
                    <option value="FJ">Fiji</option>
                    <option value="FI">Finland</option>
                    <option value="FR">France</option>
                    <option value="FX">France, Metropolitan</option>
                    <option value="GF">French Guiana</option>
                    <option value="PF">French Polynesia</option>
                    <option value="TF">French Southern Territories</option>
                    <option value="GA">Gabon</option>
                    <option value="GM">Gambia</option>
                    <option value="GE">Georgia</option>
                    <option value="DE">Germany</option>
                    <option value="GH">Ghana</option>
                    <option value="GI">Gibraltar</option>
                    <option value="GR">Greece</option>
                    <option value="GL">Greenland</option>
                    <option value="GD">Grenada</option>
                    <option value="GP">Guadeloupe</option>
                    <option value="GU">Guam</option>
                    <option value="GT">Guatemala</option>
                    <option value="GN">Guinea</option>
                    <option value="GW">Guinea-bissau</option>
                    <option value="GY">Guyana</option>
                    <option value="HT">Haiti</option>
                    <option value="HM">Heard And McDonald Islands</option>
                    <option value="VA">Holy See (Vatican City State)</option>
                    <option value="HN">Honduras</option>
                    <option value="HK">Hong Kong</option>
                    <option value="HU">Hungary</option>
                    <option value="IS">Iceland</option>
                    <option value="IN">India</option>
                    <option value="ID">Indonesia</option>
                    <option value="IR">Iran (Islamic Republic Of)</option>
                    <option value="IQ">Iraq</option>
                    <option value="IE">Ireland</option>
                    <option value="IL">Israel</option>
                    <option value="IT">Italy</option>
                    <option value="JM">Jamaica</option>
                    <option value="JP">Japan</option>
                    <option value="JO">Jordan</option>
                    <option value="KZ">Kazakhstan</option>
                    <option value="KE">Kenya</option>
                    <option value="KI">Kiribati</option>
                    <option value="KP">Korea, Democratic People's Republic Of</option>
                    <option value="KR">Korea, Republic Of</option>
                    <option value="KW">Kuwait</option>
                    <option value="KG">Kyrgyzstan</option>
                    <option value="LA">Lao People's Democratic Republic</option>
                    <option value="LV">Latvia</option>
                    <option value="LB">Lebanon</option>
                    <option value="LS">Lesotho</option>
                    <option value="LR">Liberia</option>
                    <option value="LY">Libyan Arab Jamahiriya</option>
                    <option value="LI">Liechtenstein</option>
                    <option value="LT">Lithuania</option>
                    <option value="LU">Luxembourg</option>
                    <option value="MO">Macau</option>
                    <option value="MK">Macedonia, Former Yugoslav Republic Of</option>
                    <option value="MG">Madagascar</option>
                    <option value="MW">Malawi</option>
                    <option value="MY">Malaysia</option>
                    <option value="MV">Maldives</option>
                    <option value="ML">Mali</option>
                    <option value="MT">Malta</option>
                    <option value="MH">Marshall Islands</option>
                    <option value="MQ">Martinique</option>
                    <option value="MR">Mauritania</option>
                    <option value="MU">Mauritius</option>
                    <option value="YT">Mayotte</option>
                    <option value="MX">Mexico</option>
                    <option value="FM">Micronesia, Federated States Of</option>
                    <option value="MD">Moldova, Republic Of</option>
                    <option value="MC">Monaco</option>
                    <option value="MN">Mongolia</option>
                    <option value="MS">Montserrat</option>
                    <option value="MA">Morocco</option>
                    <option value="MZ">Mozambique</option>
                    <option value="MM">Myanmar</option>
                    <option value="NA">Namibia</option>
                    <option value="NR">Nauru</option>
                    <option value="NP">Nepal</option>
                    <option value="NL">Netherlands</option>
                    <option value="AN">Netherlands Antilles</option>
                    <option value="NC">New Caledonia</option>
                    <option value="NZ">New Zealand</option>
                    <option value="NI">Nicaragua</option>
                    <option value="NE">Niger</option>
                    <option value="NG">Nigeria</option>
                    <option value="NU">Niue</option>
                    <option value="NF">Norfolk Island</option>
                    <option value="MP">Northern Mariana Islands</option>
                    <option value="NO">Norway</option>
                    <option value="OM">Oman</option>
                    <option value="PK">Pakistan</option>
                    <option value="PW">Palau</option>
                    <option value="PA">Panama</option>
                    <option value="PG">Papua New Guinea</option>
                    <option value="PY">Paraguay</option>
                    <option value="PE">Peru</option>
                    <option value="PH">Philippines</option>
                    <option value="PN">Pitcairn</option>
                    <option value="PL">Poland</option>
                    <option value="PT">Portugal</option>
                    <option value="PR">Puerto Rico</option>
                    <option value="QA">Qatar</option>
                    <option value="RE">Reunion</option>
                    <option value="RO">Romania</option>
                    <option value="RU">Russian Federation</option>
                    <option value="RW">Rwanda</option>
                    <option value="KN">Saint Kitts And Nevis</option>
                    <option value="LC">Saint Lucia</option>
                    <option value="VC">Saint Vincent And The Grenadines</option>
                    <option value="WS">Samoa</option>
                    <option value="SM">San Marino</option>
                    <option value="ST">Sao Tome And Principe</option>
                    <option value="SA">Saudi Arabia</option>
                    <option value="SN">Senegal</option>
                    <option value="SC">Seychelles</option>
                    <option value="SL">Sierra Leone</option>
                    <option value="SG">Singapore</option>
                    <option value="SK">Slovakia (Slovak Republic)</option>
                    <option value="SI">Slovenia</option>
                    <option value="SB">Solomon Islands</option>
                    <option value="SO">Somalia</option>
                    <option value="ZA">South Africa</option>
                    <option value="GS">South Georgia/South Sandwich Islands</option>
                    <option value="ES">Spain</option>
                    <option value="LK">Sri Lanka</option>
                    <option value="SH">St. Helena</option>
                    <option value="PM">St. Pierre And Miquelon</option>
                    <option value="SD">Sudan</option>
                    <option value="SR">Suriname</option>
                    <option value="SJ">Svalbard And Jan Mayen Islands</option>
                    <option value="SZ">Swaziland</option>
                    <option value="SE">Sweden</option>
                    <option value="CH">Switzerland</option>
                    <option value="SY">Syrian Arab Republic</option>
                    <option value="TW">Taiwan, Province Of China</option>
                    <option value="TJ">Tajikistan</option>
                    <option value="TZ">Tanzania, United Republic Of</option>
                    <option value="TH">Thailand</option>
                    <option value="TG">Togo</option>
                    <option value="TK">Tokelau</option>
                    <option value="TO">Tonga</option>
                    <option value="TT">Trinidad And Tobago</option>
                    <option value="TN">Tunisia</option>
                    <option value="TR">Turkey</option>
                    <option value="TM">Turkmenistan</option>
                    <option value="TC">Turks And Caicos Islands</option>
                    <option value="TV">Tuvalu</option>
                    <option value="UG">Uganda</option>
                    <option value="UA">Ukraine</option>
                    <option value="AE">United Arab Emirates</option>
                    <option value="GB">United Kingdom</option>
                    <option value="UM">United States Minor Outlying Islands</option>
                    <option value="US">United States</option>
                    <option value="UY">Uruguay</option>
                    <option value="UZ">Uzbekistan</option>
                    <option value="VU">Vanuatu</option>
                    <option value="VE">Venezuela</option>
                    <option value="VN">Vietnam</option>
                    <option value="VG">Virgin Islands (British)</option>
                    <option value="VI">Virgin Islands (U.S.)</option>
                    <option value="WF">Wallis And Futuna Islands</option>
                    <option value="EH">Western Sahara</option>
                    <option value="YE">Yemen</option>
                    <option value="YU">Yugoslavia</option>
                    <option value="ZM">Zambia</option>
                    <option value="ZW">Zimbabwe</option>
                </select>
            </div>
        </div>
    </div>
</div>

Checkbox Question

JSON

{
    "type": "checkboxes",
    "title": "What other sports have you participated in?",
    "description": "",
    "required": false,
    "read_only": false,
    "possible_answers": [{
            "id": "childcare_possible_answer-103475",
            "value": "Soccer",
            "display_value": "Soccer"
        },
        {
            "id": "childcare_possible_answer-103476",
            "value": "Basketball",
            "display_value": "Basketball"
        },
        {
            "id": "childcare_possible_answer-103477",
            "value": "Swimming",
            "display_value": "Swimming"
        },
        {
            "id": "childcare_possible_answer-103478",
            "value": "Football",
            "display_value": "Football"
        }
    ],
    "hide_empty_option": false,
    "empty_value": ""
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
    <label class="dxp-question-title">
        What other sports have you participated in?
    </label>
    <small class="dxp-question-help-text"></small>
    <div class="dxp-question-body">
        <div class="dxp-checkbox">
            <label>
                <input type="checkbox" name="childcare_answerlist-211432" value="childcare_possible_answer-103475">
                Soccer
            </label>
            <label>
                <input type="checkbox" name="childcare_answerlist-211432" value="childcare_possible_answer-103476">
                Basketball
            </label>
            <label>
                <input type="checkbox" name="childcare_answerlist-211432" value="childcare_possible_answer-103477">
                Swimming
            </label>
            <label>
                <input type="checkbox" name="childcare_answerlist-211432" value="childcare_possible_answer-103478">
                Football
            </label>
        </div>
    </div>
</div>

Date Question

JSON

{
  "type": "date",
  "title": "What is your birthdate?",
  "description": "This is required to determine eligibility.",
  "required": true,
  "read_only": false
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
    <label class="dxp-question-title">
        Birthdate
        <span class="dxp-required-indicator">*</span>
    </label>
    <small class="dxp-question-help-text"></small>
    <div class="dxp-question-body">
        <div>
            <input type="text" class="datepicker-input" placeholder="MM/DD/YYYY" maxlength="10" value="" id="P1267363601" aria-haspopup="true"
                aria-expanded="false" aria-readonly="false" aria-owns="P1267363601_root">
            <div class="datepicker-wrap" id="P1267363601_root" aria-hidden="true">
                <!-- datepicker.js internals -->
            </div>
            <a class="datepicker-icon">
                <!-- datepicker.js internals -->
            </a>
        </div>
    </div>
</div>

Dropdown Question

JSON

{
  "type": "dropdown",
  "title": "Gender",
  "description": "",
  "required": true,
  "read_only": false,
  "default_value": "U",
  "possible_answers": [{
      "id": "U",
      "value": "Unspecified",
      "display_value": "Unspecified"
    },
    {
      "id": "M",
      "value": "Male",
      "display_value": "Male"
    },
    {
      "id": "F",
      "value": "Female",
      "display_value": "Female"
    }
  ],
  "hide_empty_option": true,
  "empty_value": "U"
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
  <label class="dxp-question-title">
    Gender
    <span class="dxp-required-indicator">*</span>
  </label>
  <small class="dxp-question-help-text"></small>
  <div class="dxp-question-body">
    <div class="dxp-dropdown">
      <select class="">
        <option value="U">Unspecified</option>
        <option value="M">Male</option>
        <option value="F">Female</option>
      </select>
    </div>
  </div>
</div>

Email Question

JSON

{
  "type": "email",
  "title": "E-mail address",
  "description": "We will not send unsolicited emails.",
  "required": true,
  "read_only": false,
  "max_length": 100,
  "pattern": "^\\w+([-+.']\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*$"
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
  <label class="dxp-question-title">
    E-mail address
    <span class="dxp-required-indicator">*</span>
  </label>
  <small class="dxp-question-help-text">We will not send you any unsolicited email.</small>
  <div class="dxp-question-body">
    <input type="text" maxlength="100" value="" class="">
  </div>
</div>

Name Question

JSON

{
    "type": "name",
    "title": "Participant Name",
    "description": "Please provide the name given on your birth certificate",
    "required": true,
    "read_only": false,
    "show_first": true,
    "show_middle": true,
    "show_last": true,
    "show_prefix": true,
    "show_suffix": true,
    "required_first": true,
    "required_middle": false,
    "required_last": true,
    "prefixes": [{
            "id": "Mr.",
            "value": "Mr."
        },
        {
            "id": "Ms.",
            "value": "Ms."
        },
        {
            "id": "Mrs.",
            "value": "Mrs."
        },
        {
            "id": "Miss",
            "value": "Miss"
        },
        {
            "id": "Dr.",
            "value": "Dr."
        },
        {
            "id": "Rev.",
            "value": "Rev."
        },
        {
            "id": "Rab.",
            "value": "Rab."
        },
        {
            "id": "Can.",
            "value": "Can."
        },
        {
            "id": "Hon.",
            "value": "Hon."
        }
    ],
    "suffixes": [{
            "id": "Jr.",
            "value": "Jr."
        },
        {
            "id": "Sr.",
            "value": "Sr."
        },
        {
            "id": "I",
            "value": "I"
        },
        {
            "id": "II",
            "value": "II"
        },
        {
            "id": "III",
            "value": "III"
        },
        {
            "id": "IV",
            "value": "IV"
        },
        {
            "id": "V",
            "value": "V"
        }
    ]
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
    <label class="dxp-question-title">
        Participant Name
        <span class="dxp-required-indicator">*</span>
    </label>
    <small class="dxp-question-help-text">Please provide the name given on your birth certificate.</small>
    <div class="dxp-question-body">
        <div class="dxp-name-question">
            <div class="dxp-name-prefix">
                <label class="dxp-name-prefix-label">Prefix</label>
                <select class="dxp-name-prefix-select">
                    <option></option>
                    <option value="Mr.">Mr.</option>
                    <option value="Ms.">Ms.</option>
                    <option value="Mrs.">Mrs.</option>
                    <option value="Miss">Miss</option>
                    <option value="Dr.">Dr.</option>
                    <option value="Rev.">Rev.</option>
                    <option value="Rab.">Rab.</option>
                    <option value="Can.">Can.</option>
                    <option value="Hon.">Hon.</option>
                </select>
            </div>
            <div class="dxp-name-first">
                <label class="dxp-name-first-label">First</label>
                <input type="text" maxlength="50" class="" value="">
            </div>
            <div class="dxp-name-middle">
                <label class="dxp-name-middle-label">Middle</label>
                <input type="text" maxlength="50" class="" value="">
            </div>
            <div class="dxp-name-last">
                <label class="dxp-name-last-label">Last</label>
                <input type="text" maxlength="50" class="" value="">
            </div>
            <div class="dxp-name-suffix">
                <label class="dxp-name-suffix-label">Suffix</label>
                <select class="dxp-name-suffix-select">
                    <option></option>
                    <option value="Jr.">Jr.</option>
                    <option value="Sr.">Sr.</option>
                    <option value="I">I</option>
                    <option value="II">II</option>
                    <option value="III">III</option>
                    <option value="IV">IV</option>
                    <option value="V">V</option>
                </select>
            </div>
        </div>
    </div>
</div>

Phone Question

JSON

{
  "type": "phone",
  "title": "Home Phone",
  "description": "This will be used in case of any emergencies.",
  "required": true,
  "read_only": false,
  "show_extension": true,
  "intl": false
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
    <label class="dxp-question-title">
        Home Phone
        <span class="dxp-required-indicator">*</span>
    </label>
    <small class="dxp-question-help-text">This will be used in case of any emergencies.</small>
    <div class="dxp-question-body">
        <div class="dxp-phone-question">
            <div class="dxp-phone-number">
                <input type="tel" class="" maxlength="14" value="">
            </div>
            <div class="dxp-phone-ext-container">
                <label class="dxp-phone-ext-label">Ext.</label>
                <div class="dxp-phone-ext">
                    <input type="text" maxlength="5" class="" value="">
                </div>
            </div>
        </div>
    </div>
</div>

Radio Question

JSON

{
    "type": "radio",
    "title": "Have you participated in this program before?",
    "description": "",
    "required": false,
    "read_only": false,
    "default_value": null,
    "possible_answers": [{
            "id": "childcare_possible_answer-103473",
            "value": "Yes",
            "display_value": "Yes"
        },
        {
            "id": "childcare_possible_answer-103474",
            "value": "No",
            "display_value": "No"
        }
    ],
    "hide_empty_option": false,
    "empty_value": ""
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
    <label class="dxp-question-title">
        Have you participated in this program before?
    </label>
    <small class="dxp-question-help-text"></small>
    <div class="dxp-question-body">
        <div class="dxp-radio">
            <label>
                <input type="radio" name="childcare_answerlist-211427" value="childcare_possible_answer-103473" class="">
                Yes
            </label>
            <label>
                <input type="radio" name="childcare_answerlist-211427" value="childcare_possible_answer-103474" class="">
                No
            </label>
        </div>
    </div>
</div>

Text Question

JSON

{
  "type": "text",
  "title": "Please specify any food allergies",
  "description": "For example, peanuts, dairy, eggs, gluten, wheat, etc.",
  "required": false,
  "read_only": false,
  "max_length": 50
}

HTML

<div class="dxp-question-container dxp-key-some_id-123456">
    <label class="dxp-question-title">
        Please specify any food allergies?
    </label>
    <small class="dxp-question-help-text">For example, peanuts, dairy, eggs, gluten, wheat, etc.</small>
    <div class="dxp-question-body">
        <input type="text" maxlength="50" value="" class="">
    </div>
</div>

Javascript API

Classes

Typedefs

DxpQuestions

Kind: global class

new DxpQuestions()

DxpQuestions class

dxpQuestions.render()

Renders the form

Kind: instance method of DxpQuestions
Example

var form = DxpQuestions.init(// params);
form.render();

dxpQuestions.requestSubmit()

When called, calls the function that submits the form

Kind: instance method of DxpQuestions
Example

var form = DxpQuestions.init(// params);
form.requestSubmit();

dxpQuestions.setAnswers()

Sets answers in the form.

Kind: instance method of DxpQuestions

| Param | Type | Description | | --- | --- | --- | | params.answers | Object | The answer key/value pairs to set | | param.replaceAll | bool | Set to true to replace all answer values, false to only replace values that have a key in params.answers. Defaults to false. |

Example

var form = DxpQuestions.init(// params);
var values = {};
values['my_field_1234'] = 'Some value';
form.setAnswers({ answers: values, replaceAll: false });

DxpQuestions.init(params) ⇒ Object

Initialize a new form that will render questions and answers

Kind: static method of DxpQuestions
Returns: Object - An instance of the form

| Param | Type | Description | | --- | --- | --- | | params | Object | The parameters used to initialize the form | | params.questions | Array | A list of questions to render | | params.answers | Array | A list of answers to render | | params.container | Object | The HTML element that will contain the rendered form | | params.onFieldValidate | Object | Mapping of question id to custom validation function | | params.onFieldChange | Object | Mapping of question id to custom on change function | | params.onValidate | onValidate | A callback function that is called everytime an answer is validated | | params.onSubmit | onSubmit | A callback function that is called when the submitRequest() method is called on the form |

Example

var form = DxpQuestions.init({
  questions: // questions object here,
  answers: // answers object here,
  container: document.getElementById('container'),
  onFieldValidate: {
        'custom_field_id-12345': function(context) {
            var errors = {};
            if (context.answer.indexOf('@gmail.com') < 0) {
                errors['_summary'] = 'must be a gmail adress';
            }
            context.setErrors({ errors: errors })
        }
  },
  onFieldChange: function(context) {
     'custom_field_id-56789': function(context) {
            context.setExtraHtml('This is a calculated value of ' + context.answer);
        }
  },
  onValidate: function (result) { 
    // show error if result.valid === false
  },
  onSubmit: function (result) {
    // make API call with result.answers
  }
})

onValidate : function

Kind: global typedef

| Param | Type | Description | | --- | --- | --- | | result | Object | A callback when a validation event has occurred | | result.valid | bool | Indicates if the all questions in the form are valid |

onSubmit : function

Kind: global typedef

| Param | Type | Description | | --- | --- | --- | | result | Object | A callback that is executed when requestSubmit() is called | | result.valid | bool | Indicates if the all questions in the form are valid | | result.answers | Object | The list of all the answers | | result.errors | Object | The lsit of all the errors |