iflrandevu/assets/js/pages/backend_calendar_api.js

148 lines
5.1 KiB
JavaScript
Raw Normal View History

/* ----------------------------------------------------------------------------
* Easy!Appointments - Open Source Web Scheduler
*
* @package EasyAppointments
* @author A.Tselegidis <alextselegidis@gmail.com>
* @copyright Copyright (c) 2013 - 2020, Alex Tselegidis
* @license http://opensource.org/licenses/GPL-3.0 - GPLv3
* @link http://easyappointments.org
* @since v1.2.0
* ---------------------------------------------------------------------------- */
/**
* Backend Calendar API
*
* This module implements the AJAX requests for the calendar page.
*
* @module BackendCalendarApi
*/
window.BackendCalendarApi = window.BackendCalendarApi || {};
2018-01-23 12:08:37 +03:00
(function (exports) {
'use strict';
/**
* Save Appointment
*
* This method stores the changes of an already registered appointment into the database, via an ajax call.
*
* @param {Object} appointment Contain the new appointment data. The ID of the appointment MUST be already included.
* The rest values must follow the database structure.
* @param {Object} [customer] Optional, contains the customer data.
* @param {Function} [successCallback] Optional, if defined, this function is going to be executed on post success.
* @param {Function} [errorCallback] Optional, if defined, this function is going to be executed on post failure.
*/
2018-01-23 12:08:37 +03:00
exports.saveAppointment = function (appointment, customer, successCallback, errorCallback) {
var url = GlobalVariables.baseUrl + '/index.php/calendar/ajax_save_appointment';
var data = {
csrfToken: GlobalVariables.csrfToken,
appointment_data: JSON.stringify(appointment)
};
if (customer) {
data.customer_data = JSON.stringify(customer);
}
$.post(url, data)
2018-01-23 12:08:37 +03:00
.done(function (response) {
if (successCallback) {
successCallback(response);
}
})
2018-01-23 12:08:37 +03:00
.fail(function (jqXHR, textStatus, errorThrown) {
if (errorCallback) {
errorCallback();
}
});
};
/**
* Save unavailable period to database.
*
2016-10-10 19:29:48 +03:00
* @param {Object} unavailable Contains the unavailable period data.
* @param {Function} successCallback The ajax success callback function.
* @param {Function} errorCallback The ajax failure callback function.
*/
2018-01-23 12:08:37 +03:00
exports.saveUnavailable = function (unavailable, successCallback, errorCallback) {
var url = GlobalVariables.baseUrl + '/index.php/calendar/ajax_save_unavailable';
var data = {
csrfToken: GlobalVariables.csrfToken,
unavailable: JSON.stringify(unavailable)
};
$.post(url, data)
.done(function (response) {
if (successCallback) {
successCallback(response);
}
})
.fail(function (jqXHR, textStatus, errorThrown) {
if (errorCallback) {
errorCallback();
}
});
};
/**
* Save working plan exception of work to database.
*
* @param {Date} date Contains the working plan exceptions data.
* @param {Object} workingPlanException Contains the working plan exceptions data.
* @param {Number} providerId Contains the working plan exceptions data.
* @param {Function} successCallback The ajax success callback function.
* @param {Function} errorCallback The ajax failure callback function.
*/
exports.saveWorkingPlanException = function (
date,
workingPlanException,
providerId,
successCallback,
errorCallback
) {
var url = GlobalVariables.baseUrl + '/index.php/calendar/ajax_save_working_plan_exception';
var data = {
csrfToken: GlobalVariables.csrfToken,
date: date,
working_plan_exception: workingPlanException,
provider_id: providerId
};
$.post(url, data)
.done(function (response) {
if (successCallback) {
successCallback(response);
}
})
.fail(function (jqXHR, textStatus, errorThrown) {
if (errorCallback) {
errorCallback();
}
});
};
exports.deleteWorkingPlanException = function (date, providerId, successCallback, errorCallback) {
var url = GlobalVariables.baseUrl + '/index.php/calendar/ajax_delete_working_plan_exception';
var data = {
csrfToken: GlobalVariables.csrfToken,
date: date,
provider_id: providerId
};
$.post(url, data)
.done(function (response) {
if (successCallback) {
successCallback(response);
}
})
.fail(function (jqXHR, textStatus, errorThrown) {
if (errorCallback) {
errorCallback();
}
});
};
})(window.BackendCalendarApi);