UNPKG

use-search-params

Version:

A React Hook to use the URLSearchParams utility methods

87 lines (67 loc) 2.52 kB
"use strict"; 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;