8.4.3.1. Calendars

eXo Platform provides APIs to create, update, delete and get information of a calendar.

Getting information of a calendar

  1. Replace content of the CalendarHTTPRequestGadget.xml file with this script:

    
    <?xml version="1.0" encoding="UTF-8" ?>
    <Module>
        <ModulePrefs title="Calendar HTTP Request Gadget">
            <Require feature="opensocial-0.8" />
        </ModulePrefs>
        <Content type="html">
            <![CDATA[
                <!--Including platform css-->
                <link href="/eXoSkin/skin/css/Core.css" rel="stylesheet"></link>
                <link href="/eXoSkin/skin/css/sub-core.css" rel="stylesheet"></link>
                <!--Including JQuery library-->
                <script src="jquery-2.1.3.js"></script>
                <!--Gadget's main body which will be added by HTML DOM Object later-->
                <div id="calendar-show" style="max-width: 800px" class="uiComposer uiGrayLightBox">
                        <div class="input-append" style="margin: 20px 30px 20px 30px">
                            //control button for getting default calendar of the current logged-in user
                            <button id="get_default_cal_btn" onclick="getDefaultCalendar()" class="btn btn-primary" >Get default calendar</button>
                            //control button for getting a calendar by id
                            <button id="get_calid_btn" onclick="getCalendarById()" class="btn btn-primary">Get calendar by id</button><input type="text" id="calid_txt" placeholder="Enter calendar id...">
                        </div>
                </div>
                <!--Start calling js function-->
                <script type="text/javascript">
                    //get the current logged-in user via OpenSocial
                    var current_user;
                    loadViewer();
                    function loadViewer() {
                      var req = opensocial.newDataRequest();
                      req.add(req.newFetchPersonRequest(opensocial.IdSpec.PersonId.VIEWER), 'viewer');
                      req.send(onLoadViewer);
                    }
                    function onLoadViewer(data) {
                      var viewer = data.get('viewer').getData();
                      //get current user
                      current_user = viewer.getId();
                    }]]>
        </Content>
    </Module>
  2. Deploy this gadget. You will see what is going next.

    This UI offers 2 functions which are: getting the default calendar or retrieving other calendars by entering a specified Id.

  3. Implement the getDefaultCalendar() function by adding the following source code to the Javascript paragraph of the gadget:

    function getDefaultCalendar(){
    					//get default calendar of the current logged-in user
    					//This function uses AJAX to send GET request to 
    					//Calendar REST API GET /rest/private/v1/calendar/calendars/
    					$.ajax({
    						 type: "GET",
    						 url: "/rest/private/v1/calendar/calendars/"+current_user+"-defaultCalendarId",
    						 success: function (data, status, jqXHR) {
    							  processGetCalendar(data);
    						 },
    						 error: function (jqXHR, status) {
    							 alert("Cannot retrieve data!");
    						 }
    					});
    				}

    The above function uses an Ajax GET request. It calls the REST API /rest/private/v1/calendar/calendars/ and passes *-defaultCalendarId which is the default calendar's Id of the current logged-in user. If successful, the result will then be passed through the processGetCalendar() function. This function will be implemented later.

  4. Consider how to get and pass the entered calendar Id to this REST API instead of hard-coding it by adding the source code:

    function getCalendarById(){
    					//get the entered calendar id
    					var cal_id=$('#calid_txt').val();
    					//This function uses AJAX to send GET request to 
    					//Calendar REST API GET /rest/private/v1/calendar/calendars/
    					$.ajax({
    						 type: "GET",
    						 url: "/rest/private/v1/calendar/calendars/"+cal_id,
    						 success: function (data, status, jqXHR) {
    							//print the result
    							  processGetCalendar(data);
    						 },
    						 error: function (jqXHR, status) {
    							 alert("Cannot retrieve data!");
    						 }
    					});
    				}

    This function uses JQuery to get value of the text box for entering calendar Id and pass it to url parameter of this call. Now, it's time to process returned results!

    The data returned from a Calendar GET request is under a JSON object. Therefore, you could implement the processGetCalendar() as below:

    function processGetCalendar(results){
    					//clean the old screen
    					$("#calendar-result").remove();
    					//add calendar object's information
    					var obj_content="<div id=\"calendar-result\"><table class=\"uiGrid table table-hover table-striped\"><thead><tr><th>Properties</th><th>Value</th></tr></thead><tbody>";
    						//loop through the calendar object's properties
    						$.each(results, function(key, value) {
    							obj_content+="<tr><td>"+key+"</td><td>"+value+"</td></tr>";
    						});
    					//add closing tag
    					obj_content+="<tr><td><b>Execute functions</b></td><td><button id=\"submit_cal_btn\" onclick=\"updateCalendar()\">Update</button>&nbsp;&nbsp;&nbsp;&nbsp;<button id=\"delete_cal_btn\" onclick=\"deleteCalendar()\">Delete</button></td></tr></tbody></table></div>";
    					//print to screen
    					$('#calendar-show').append(obj_content);
    				}
  5. Deploy and test the gadget to see what has been done by clicking Get default calendar. You will see the default calendar's information displayed:

    To test the Get calendar by id function, move to the next part of creating a new calendar.

Creating a new calendar

  1. Add a control button in front of others like this:

    ...
    	//control button for creating a new calendar
    	<button id="create_cal_btn" onclick="createCalendar()" class="btn btn-primary">Create a new calendar</button>
    	//control button for getting default calendar of the current logged-in user
    	<button id="get_default_cal_btn" onclick="getDefaultCalendar()" class="btn btn-primary" >Get default calendar</button>
    	//control button for getting a calendar by id
    	<button id="get_calid_btn" onclick="getCalendarById()" class="btn btn-primary">Get calendar by id</button><input type="text" id="calid_txt" placeholder="Enter calendar id...">
    	...
  2. Implement the createCalendar() function as below:

    function createCalendar(){
    				//clean the old screen
    				$("#calendar-result").remove();
    				//add a simple calendar input form
    				$('#calendar-show').append("<div id=\"calendar-result\"><table class=\"uiGrid table table-hover table-striped\">"+
    					"<thead><tr><th>Properties</th><th>Value</th></tr></thead><tbody>"+
    					"<tr><td>Name</td><td><input type=\"text\" id=\"cal-name\"></td></tr>"
    					+"<tr><td>Type</td><td><select id=\"cal-type\"><option value=\"0\">Personal calendar</option></select></td></tr>"
    					+"<tr><td>Description</td><td><textarea id=\"cal-description\"  rows=\"4\" cols=\"50\"></textarea></td></tr>"
    					+"<tr><td>Color</td><td><select id=\"cal-color\"><option value=\"red\">Red</option><option value=\"yellow\">Yellow</option></select></td></tr>"
    					+"<tr><td><b>Execute functions</b></td><td><button id=\"create_cal_btn\" onclick=\"submitCalendar()\">Submit</button></td></tr>"
    					+"</tbody></table></div>");
    			}

    This UI allows to create a simple calendar with properties, such as name, type, description and color.

  3. Create an Ajax POST request to call this API by implementing the submitCalendar() as follows:

    function submitCalendar(){
    					//get entered cal_json_obj
    					var cal_json_obj={
    						"name":$("#cal-name").val(),
    						"owner": current_user,
    						"type":$("#cal-type").val(),
    						"description":$("#cal-description").val(),
    						"color":$("#cal-color").val()
    						};
    					$.ajax({
    						url: "/rest/private/v1/calendar/calendars",
    						contentType: "application/json",
    						data: JSON.stringify(cal_json_obj),
    						method: "POST"
    						}).done(function (data, status, xhr) {
    						   //clean the old screen
    						   $("#calendar-result").remove();
    						   //get the newly created calendar id
    						   var locat=xhr.getResponseHeader('Location');
    						   var new_cal = locat.split("calendar/calendars/");
    						   $('#calendar-show').append("<div id=\"calendar-result\"><i>Created successfully! Calendar id: "+new_cal[1]+"</i></div>");
    						}).fail(function (jqxhr, textStatus, error) {
    							alert("fail");
    					});
    				}

    This script passes the user input as a JSON object to the POST request. If successful, the returned result will be the newly created calendar Id.

  4. Deploy this gadget to see the input form for creating a new calendar, and fill in this form like:

  5. Click Submit button to execute this function and see the message informing that you have successfully created a new calendar. For example: "Created successfully! Calendar id: calendard94b0488c0a8043a7f3b0da4a6318abf".

    To check the new calendar, copy the attached Id in this message and paste it to the input text of the Get calendar by id function. You will see its information displayed.

Updating a calendar

It is assumed that you need to update properties of a calendar, for instance its name and description. To avoid passing local variables too many times, you will use a global one called "current_cal_obj" that points to the processing calendar object.

  1. Add a declaration of this variable to the Javascript paragraph of the gadget:

    var current_cal_obj;

    Now, each time you query a calendar, this variable should be updated by adding the script:

    current_cal_obj=results;

    to the processGetCalendar() function in getting information of a calendar.

  2. Implement the updateCalendar() function as follows:

    function updateCalendar(){
    					//clean the old result
    					$("#calendar-result").remove();
    					//add new calendar object's information
    					var obj_content="<div id=\"calendar-result\"><table class=\"uiGrid table table-hover table-striped\"><thead><tr><th>Properties</th><th>Value</th></tr></thead><tbody>";
    						//loop through the new calendar object's properties
    						$.each(current_cal_obj, function(key, value) {
    							if((key=="name")||(key=="description")){
    								obj_content+="<tr><td>"+key+"</td><td><textarea id=\"cal-"+key+"\">"+value+"</textarea></td></tr>";
    							}
    							else {
    								obj_content+="<tr><td>"+key+"</td><td>"+value+"</td></tr>";
    							}
    						});
    					//add closing tag
    					obj_content+="<tr><td><b>Execute functions</b></td><td><button id=\"submit_cal_btn\" onclick=\"submitFullCalendar()\">Submit</button>&nbsp;&nbsp;&nbsp;&nbsp;<button id=\"delete_cal_btn\" onclick=\"deleteCalendar()\">Delete</button></td></tr></tbody></table></div>";
    					//add to screen
    					$('#calendar-show').append(obj_content);
    				}

    As seen above, you can easily manage the information of the processing calendar object through the global variable.

  3. Deploy the gadget and select a specific calendar, for instance the default one. Then, click the Update button, you will see the name and description fields enabled for editing mode:

    If you click the Submit button, nothing happens since you have not implemented the submitFullCalendar() function. To make an update query, you need to send an Ajax PUT request as follows:

    function submitFullCalendar(){
    					//get changed properties
    					current_cal_obj.name=$("#cal-name").val();
    					current_cal_obj.description=$("#cal-description").val();
    					$.ajax({
    						url: "/rest/private/v1/calendar/calendars/"+current_cal_obj.id,
    						contentType: "application/json",
    						data: JSON.stringify(current_cal_obj),
    						method: "PUT"
    						}).done(function (data, status, xhr) {
    						   $("#calendar-result").remove();
    						   $('#calendar-show').append("<div id=\"calendar-result\"><i>Updated successfully!</i></div>");
    						}).fail(function (jqxhr, textStatus, error) {
    							alert("fail");
    					});
    				}
  4. Add this function to the Javascript paragraph of the gadget and redeploy it. Now, test your update function and see how it works!

Deleting a calendar

To delete a calendar, you need to make an Ajax DELETE request by implementing the deleteCalendar() function as follows:

function deleteCalendar(){
					$.ajax({
						url: "/rest/private/v1/calendar/calendars/"+current_cal_obj.id,
						method: "DELETE"
						}).done(function () {
						   $("#calendar-result").remove();
						   $('#calendar-show').append("<div id=\"calendar-result\"><i>Deleted successfully!</i></div>");
						}).fail(function (jqxhr, textStatus, error) {
							alert("fail");
					});
				}

This function gets the processing calendar Id from the global variable "current_cal_obj" for passing to the url parameter. And now, deploy this gadget to test this function.

Copyright ©. All rights reserved. eXo Platform SAS
blog comments powered byDisqus