Versions Compared

Key

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

Table of Contents

 


Objective:

Through Thru this functionality , users can create their own Widget widget to embed embebed in web sites in order to access KIBE (KIU INTERNET BOOKING ENGINE) functionalities. 

This document explains will explain how to configure the widget and also shows show some examples for developers.


Concepts

 

What is a Widget?

 It  -  it is a form on HTML with .CSS that could be embedded embebed into an iframe on the client´s web page or other sites.

Does KIU offer a Widgetwidget?  

 - Yes. , KIU provides a standard Widget when creating create the KIBE for clients, supply a standard widget, but it is maybe this not adjustable adjust to the customer´s web site.

Is the custom Widget based on the KIBE general configuration?

The Widget is indeed based on website customer requirements and decide to create one. 

Does the custom widget takes the general configuration of the KIBE?

 - The widget MUST take the configuration and content of the site in order to be accomplish with the operating and commercial requirements intends of the client. All this information resides reside on the KIBE Backoffice and backoffice that should be completely configurated once the Widget is created. Within at time of widget´s creation.  During this document , you will see many examples of how the way to connect your custom Widget widget with the KIBE.  


How to get

KIBE

content to build a

Widget

widget.

When a user creates create a form in order to build a widget for KIBE, there are some mandatory fields that it should have had in order to send the minimal information to make it work and get content.

To get that content and the information required for the KIBE application to work, the developers have to add the next Script into the head tag of the form.

Code Block
languageactionscript3
themeDJango
 <script>
            $(document).ready(function(){
                $.ajax({
                    url: "[KIBE URL domain]/api/get_complete_config_widget/",
                    success: function(response){ formatResponse(response);},
                    dataType: "jsonp"
                });
                //ExampleEjemplo onsobre howcomo toconsumir consumela the data
                function formatResponse(response){
                    $("#csrfmiddlewaretoken").val(response.csrf_token);
                    $.each(response.airports.keys.origin, function(i,e){ 
                                  $("#id_origin").append("<option value='"+ e.data +"'>"+ e.value +"</option>")               
                    })
                    $.each(response.airports.keys.destination, function(i,e){ 
                                  $("#id_destination").append("<option value='"+ e.data +"'>"+ e.value +"</option>")               
                    })
                }
            });
        </script>

 

 - URL: The KIBE domain It has to be declared the KIBE domain (This data is provided by KIU once KIBE is created), at time of KIBE creation for client) followed by the parameters /api/get_complete_config_widget/. (EgEx: https://kibe-dev-xx.kiusys.net/api/get_complete_config_widget/).

This URL will return the next JSON API:.

Code Block
languagecss
themeFadeToGrey
{
  "passengers": {
    "max_pax_allowed": 9,
    "pax_config": [
      {
        "max_age": null,
        "enable": true,
        "name": "ADULT",
        "min_age": 12
      },
      {
        "max_age": 12,
        "enable": true,
        "name": "CHILD",
        "min_age": 2
      },
      {
        "max_age": 2,
        "enable": true,
        "name": "INFANT",
        "min_age": 0
      }
    ]
  },
  "csrf_token": "vgTgLRd6L1XKeeJdWdMSPDOhyUURzF02XJUl0CarwNc3ABHAQeWdMkmgi93QMVOI",
  "airports": {
    "keys": {
      "origin": [
        {
          "code": "AEP",
          "data": "QUVQ",
          "value": "BUENOS AIRES (BUE), JORGE NEWBERY AIRPORT (AEP), Argentina"
        }
      ],
      "destination": [
        {
          "code": "MDQ",
          "data": "TURR",
          "value": "MAR DEL PLATA (MDQ), ASTOR PIAZZOLA AIRPORT - MERY (MDQ), Argentina"
        },
        {
          "code": "LAS",
          "data": "TEFT",
          "value": "LAS VEGAS (LAS), MCCARRAN INTERNATIONAL AIRPORT (LAS), United States"
        }
      ]
    }
  },
  "origin_destination": {
    "keys": [
      {
        "origin": "AEP",
        "destination": "MDQ",
        "not_flying_days_return": [],
        "not_flying_days_going": [],
        "frequency_return": [
          0,
          1,
          2,
          3,
          4,
          5,
          6
        ],
        "frequency_going": [
          0,
          1,
          2,
          3,
          4,
          5,
          6
        ],
        "direct_fly": false
      }
    ]
  }
}

 

Response Dictionarydictionary:

KeyDescriptionValues / Format
PassengersSupported Hold and object with the configuration of the passenger types supported and maximum max.quantity allowed.ObjectObjecto
max_pax_allowedMaximum quantity of This key contain the max. quantity passengers allowed.Integer
pax_config

Supported passenger types (It is an object with with the configuration allowed for categories of passenger types. These are: ADULT, CHILD and INFANT).

ObjectObjecto
max_ageMaximum Related to the max. age allowed per passenger category. It is inside the pax_config node.Integer / null
enableThis is a toggle that indicates indicate if a category is enabled enable or disableddisable. It is inside pax_config node.true / false
nameThis is the name of the passenger category. It is inside pax_config.ADULT / CHILD / INFANT
min_ageThe minimum age allowed allowd for each category. It is inside the pax_config pax_config node.Integer
csrf_tokenThis is a the hash for validation purposes that must be included in include on the form submit.HASH
airportsIt is an object that contains contain the information of valid airports set for customer. This information is offered offer for validation purposes of the form at client level. (Front-end validation).Object
keysObject. List of origins - destinations set on Backoffice back office as allowed routes. This key is inside the object airport. It represents Represent which origin to which destination is allowed to request content.Object
originList of enabled origin airports onlyenable airports for origin exclusively. This field is inside Keys node.Array
codeISO IATA airport code for origin field. This key is inside the Origin node.3 Alphabetical chars
dataThis is internal for internal KIBE purposes uses only!.4 Alphabetical chars
valueDescription associated to the airport code. This key is inside the Origin node.Alphabetical
destinationList of enabled destination airports onlyenable airports for destination exclusively. This field fiel is inside Keys node.Object
codeISO IATA airport code for destination origin field. This key is inside the Destination Origin node.3 Alphabetical chars
dataThis is internal for internal KIBE purposes uses only!.4 Alphabetical chars
valueDescription associated to the airport code. This key is inside the Destination Origin node.Alphabetical
origin_destinationObject. List of enabled commercial routes set in the KIBE Backofficeroutes enables for commercialization into the back-Office of KIBE.Object
keysList of objects that contains contain the offered pair of airports enabledenables to offer. This key is inside the origin_destination node.Array
originISO IATA Airport code corresponding to the origin airport code. It is inside the Keys node.3 Alphabetical chars
destinationISO IATA Airport code corresponding to the destination airport code. It is inside the Keys node.3 Alphabetical chars
not_flying_days_returnList of week days for that return flights flight is not enabled enable to operate. It is inside the Keys node.0 to 6 (0:Monday; 1: ; Tuesday, ..etc.)
not_flying_days_goingList of week week´s days for that origin flights flight is not enabled enable to operate. It is inside the Keys node.0 to a 6 (0: Monday; 1:Tuesday, etc.....etc.)
frequency_returnList of days of a week days for that return flight enabled is enable to operate. It is inside the Keys node.0 to a 6 (0: Monday; 1:Tuesday, ....etc.)
frequency_goingList of days of week days for origin flights enabled that the origin flight is enable to operate. It is inside the Keys node.0 to a 6 (0: Monday; 1:Tuesday, ....etc.)
direct_flyToggle that display if the flight is direct or of allows connections.true / false



 

Developers based on this response now have the enough data enough to build/display content on Widget field like origin-destination and make the validations of routes enabled to search, types of passengers and quantity of passengers enabled to search and type of trips (One Way and Round Trip flights).widget fields like:

  • Origin - Destination: Populate the airports on the origin field and the destination field. Create a validation for pair of airports enables for search.
  • Travel Type: Create a routine to allow user to search one way and round trips travels depending the enabled routes. 
  • Travelers: List of supported passenger types and the ages for limit and validate each of them. 
  • Departure and return Date: Create field that allow user to add departure date and return date in case the Round trip flights is enabled. 

 


Search Flights:

When processing At time to process the form and redirecting redirect to the KIBE, inside into the Form form tag , in on the Action action attribute, the destination target URL must be the KIBE domain , and the Method method tag needs , need to be 'POST'.

ExampleEx:

Code Block
languagexml
themeFadeToGrey
 <form class="searcher" id="search-form" name="searchWidgetForm" action="https://kibe-dev-xx.kiusys.net/" method="POST">

 

When user clicks on Declared this, when the user click over the submit button, KIBE will gather all the parameters (to execute the query: Origin, Destination, DepartureDate, ReturnDate - (If it it´s exists - ), Adult Adults quantity, Child Childs quantity, Infant quantity) and then it will process the request and display the results into the environment of KIBE page in order to infants quantity. The result of the seach will be display into the  KIBE´s result page  and complete the booking flow, normally. 

 

 


Anexo 1:

 

Validations recommended:

So far the KIBE has back-end validations, we strong recommend to developers pay attention to some validation on the front-end side that will make the process more efficient:

 

  1. Origin - Destination: 
    The response of the JSON API return the routes enabled for search, configured on the back office of the KIBE. Based on this information, developer can allow only search that include an origin with only those destination airports that match and be returned on the response. 

  2. Dates:
    The date format supported is DD-MM-YYYY. Developer can display on different format that feels more comfortable for user experience, but, they need to transform on the format mentioned in order to avoid any validation error returned from KIBE.

  3. Departure Date: 
    The departure date must be from current date in advance and not beyond 330 days in future.

  4. ReturnDate: 
    The return date should be validating to be never before departure date and not beyond 330 days in future. 

  5. Adult Passenger:
    We recommend that the default value for adult passenger should be 1 and not allowed 0. This will avoid any possibility for unaccompanied minors (this should be resolved on Airline offices).

  6. Infant passengers:
    For industry logic, there should be at least one adult for infant passenger only. If there are more than one infant it must be more than one adult for association purposes.