/* ---------------------------------------------------------------------------- * Easy!Appointments - Online Appointment Scheduler * * @package EasyAppointments * @author A.Tselegidis <alextselegidis@gmail.com> * @copyright Copyright (c) Alex Tselegidis * @license https://opensource.org/licenses/GPL-3.0 - GPLv3 * @link https://easyappointments.org * @since v1.5.0 * ---------------------------------------------------------------------------- */ /** * URLs utility. * * This module implements the functionality of URLs. */ window.App.Utils.Url = (function () { /** * Get complete URL of the provided URI segment. * * @param {String} uri * * @return {String} */ function baseUrl(uri) { return `${vars('base_url')}/${uri}`; } /** * Get the complete site URL (including the index.php) of the provided URI segment. * * @param {String} uri * * @returns {String} */ function siteUrl(uri) { return `${vars('base_url')}${vars('index_page') ? '/' + vars('index_page') : ''}/${uri}`; } /** * Retrieve a query parameter from the current request. * * @link http://www.netlobo.com/url_query_string_javascript.html * * @param {String} name Parameter name. * @return {String} Returns the parameter value. */ function queryParam(name) { const url = location.href; const parsedUrl = url.substr(url.indexOf('?')).slice(1).split('&'); for (let index in parsedUrl) { const parsedValue = parsedUrl[index].split('='); if (parsedValue.length === 1 && parsedValue[0] === name) { return ''; } if (parsedValue.length === 2 && parsedValue[0] === name) { return decodeURIComponent(parsedValue[1]); } } return null; } return { baseUrl, siteUrl, queryParam }; })();