@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
63 lines (62 loc) • 2.17 kB
JavaScript
;
"use client";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = useQueryLocator;
var _index = _interopRequireDefault(require("core-js-pure/stable/url/index.js"));
var _index2 = _interopRequireDefault(require("core-js-pure/stable/url-search-params/index.js"));
var _react = require("react");
var _useStep = _interopRequireDefault(require("./useStep.js"));
var _useIsomorphicLayoutEffect = require("../../../../shared/helpers/useIsomorphicLayoutEffect.js");
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
function useQueryLocator(id = undefined) {
const {
setFormError
} = (0, _useStep.default)(id);
const name = id ? `${id}-step` : 'step';
const onStepChange = (0, _react.useCallback)(index => {
try {
const url = new _index.default(window.location.href);
url.searchParams.set(name, String(index));
window.history.pushState({}, '', url.toString());
} catch (error) {
setFormError(error);
}
}, [name, setFormError]);
const {
setActiveIndex
} = (0, _useStep.default)(id, {
onStepChange
});
const getIndex = (0, _react.useCallback)(() => {
try {
const searchParams = new _index2.default(window.location.search);
return parseFloat(searchParams.get(name));
} catch (error) {
setFormError(error);
}
}, [name, setFormError]);
(0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(() => {
try {
const popstateListener = () => {
const routerIndex = getIndex();
if (!isNaN(routerIndex)) {
setActiveIndex === null || setActiveIndex === void 0 || setActiveIndex(routerIndex, {
skipStepChangeCallFromHook: true,
skipStepChangeCallBeforeMounted: true
});
}
};
popstateListener();
window.addEventListener('popstate', popstateListener);
return () => window.removeEventListener('popstate', popstateListener);
} catch (error) {
setFormError(error);
}
}, [getIndex, id, setActiveIndex, setFormError]);
return {
getIndex
};
}
//# sourceMappingURL=useQueryLocator.js.map