url-lib
Version:
A simple, lightweight string utility for Node and browsers that supports serializing and parsing URLs and query strings.
50 lines (36 loc) • 1.78 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _utils = require("./utils");
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); }
function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); }
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }
var IMMUTABLE_EMPTY_OBJECT = {};
/**
* Serializes the properties of a params object to produce a URL query string.
* @param {NullableUrlParams | NullableUrlParams[]} [urlParams] - An object (or array of objects) representing the query
* @returns {string} Serialized query string
*/
var formatQuery = function formatQuery(urlParams) {
var paramsObj = urlParams;
if (Array.isArray(paramsObj)) {
paramsObj = paramsObj.length < 2 ? paramsObj[0] : Object.assign.apply(Object, [{}].concat(_toConsumableArray(paramsObj)));
}
var normalizedParams = paramsObj || IMMUTABLE_EMPTY_OBJECT;
return Object.keys(normalizedParams).reduce(function (prevUrlParamPairs, paramName) {
var urlParamPairs = prevUrlParamPairs;
var paramValue;
if (paramName) {
paramValue = normalizedParams[paramName];
if (paramValue != null) {
urlParamPairs.push("".concat((0, _utils.encode)(paramName), "=").concat((0, _utils.encode)(paramValue)));
}
}
return urlParamPairs;
}, []).join('&');
};
var _default = formatQuery;
exports.default = _default;