use-search-params
Version:
A React Hook to use the URLSearchParams utility methods
87 lines (67 loc) • 2.52 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = require("react");
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
function _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
var useSearchParams = function useSearchParams() {
var _useState = (0, _react.useState)(new URLSearchParams(window.location.search)),
_useState2 = _slicedToArray(_useState, 1),
searchParams = _useState2[0];
var _useState3 = (0, _react.useState)(searchParams.toString()),
_useState4 = _slicedToArray(_useState3, 2),
queryString = _useState4[0],
setQueryString = _useState4[1];
var append = function append(name, value) {
searchParams.append(name, value);
setQueryString(searchParams.toString());
};
var entries = function entries() {
return Array.from(searchParams.entries());
};
var get = function get(name) {
return searchParams.get(name);
};
var getAll = function getAll(name) {
return searchParams.getAll(name);
};
var has = function has(name) {
return searchParams.has(name);
};
var keys = function keys() {
return Array.from(searchParams.keys());
};
var remove = function remove(name) {
searchParams["delete"](name);
setQueryString(searchParams.toString());
};
var set = function set(name, value) {
searchParams.set(name, value);
setQueryString(searchParams.toString());
};
var sort = function sort() {
searchParams.sort();
setQueryString(searchParams.toString());
};
var values = function values() {
return Array.from(searchParams.values());
};
return [queryString, {
append: append,
entries: entries,
get: get,
getAll: getAll,
has: has,
keys: keys,
remove: remove,
set: set,
sort: sort,
values: values
}];
};
var _default = useSearchParams;
exports["default"] = _default;