1 | "use strict";
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports["default"] = void 0;
|
7 |
|
8 | var _react = require("react");
|
9 |
|
10 | var _useGeolocationEvents2 = _interopRequireDefault(require("./useGeolocationEvents"));
|
11 |
|
12 | var _geolocationStandardOptions = _interopRequireDefault(require("./utils/geolocationStandardOptions"));
|
13 |
|
14 | var _makePositionObject = _interopRequireDefault(require("./utils/makePositionObject"));
|
15 |
|
16 | var _isSamePosition = _interopRequireDefault(require("./utils/isSamePosition"));
|
17 |
|
18 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
19 |
|
20 | function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }
|
21 |
|
22 | function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance"); }
|
23 |
|
24 | function _iterableToArrayLimit(arr, i) { if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === "[object Arguments]")) { return; } 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; }
|
25 |
|
26 | function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
27 |
|
28 | var useGeolocationState = function useGeolocationState() {
|
29 | var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _geolocationStandardOptions["default"];
|
30 |
|
31 | var _useState = (0, _react.useState)(null),
|
32 | _useState2 = _slicedToArray(_useState, 2),
|
33 | position = _useState2[0],
|
34 | setPosition = _useState2[1];
|
35 |
|
36 | var _useState3 = (0, _react.useState)(false),
|
37 | _useState4 = _slicedToArray(_useState3, 2),
|
38 | isRetrieving = _useState4[0],
|
39 | setRetrieving = _useState4[1];
|
40 |
|
41 | var _useGeolocationEvents = (0, _useGeolocationEvents2["default"])(options),
|
42 | isSupported = _useGeolocationEvents.isSupported,
|
43 | onChange = _useGeolocationEvents.onChange;
|
44 |
|
45 | var savePosition = (0, _react.useCallback)(function () {
|
46 | if (position === null) {
|
47 | setRetrieving(true);
|
48 | navigator.geolocation.getCurrentPosition(function (nextPosition) {
|
49 | if (!(0, _isSamePosition["default"])(position, nextPosition)) {
|
50 | setPosition((0, _makePositionObject["default"])(nextPosition));
|
51 | setRetrieving(false);
|
52 | }
|
53 | });
|
54 | }
|
55 | }, [position]);
|
56 | (0, _react.useEffect)(savePosition, [position]);
|
57 | onChange(savePosition);
|
58 | return Object.freeze({
|
59 | isSupported: isSupported,
|
60 | isRetrieving: isRetrieving,
|
61 | position: position
|
62 | });
|
63 | };
|
64 |
|
65 | var _default = useGeolocationState;
|
66 | exports["default"] = _default;
|
67 |
|