@grantpearceuk/hooks 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +403 -0
- package/lib/cjs/global.d.d.ts +7 -0
- package/lib/cjs/global.d.js +2 -0
- package/lib/cjs/index.d.ts +32 -0
- package/lib/cjs/index.js +69 -0
- package/lib/cjs/useArray/index.d.ts +2 -0
- package/lib/cjs/useArray/index.js +43 -0
- package/lib/cjs/useAsync/index.d.ts +2 -0
- package/lib/cjs/useAsync/index.js +29 -0
- package/lib/cjs/useClickOutside/index.d.ts +5 -0
- package/lib/cjs/useClickOutside/index.js +14 -0
- package/lib/cjs/useCookie/index.d.ts +2 -0
- package/lib/cjs/useCookie/index.js +26 -0
- package/lib/cjs/useCopyToClipboard/index.d.ts +2 -0
- package/lib/cjs/useCopyToClipboard/index.js +20 -0
- package/lib/cjs/useDarkMode/index.d.ts +4 -0
- package/lib/cjs/useDarkMode/index.js +18 -0
- package/lib/cjs/useDebounce/index.d.ts +2 -0
- package/lib/cjs/useDebounce/index.js +22 -0
- package/lib/cjs/useDebugInformation/index.d.ts +8 -0
- package/lib/cjs/useDebugInformation/index.js +44 -0
- package/lib/cjs/useDeepCompareEffect/index.d.ts +2 -0
- package/lib/cjs/useDeepCompareEffect/index.js +16 -0
- package/lib/cjs/useEffectOnce/index.d.ts +1 -0
- package/lib/cjs/useEffectOnce/index.js +7 -0
- package/lib/cjs/useEventListener/index.d.ts +2 -0
- package/lib/cjs/useEventListener/index.js +18 -0
- package/lib/cjs/useFetch/index.d.ts +2 -0
- package/lib/cjs/useFetch/index.js +82 -0
- package/lib/cjs/useGenerateHtmlId/index.d.ts +3 -0
- package/lib/cjs/useGenerateHtmlId/index.js +9 -0
- package/lib/cjs/useGeolocation/index.d.ts +2 -0
- package/lib/cjs/useGeolocation/index.js +26 -0
- package/lib/cjs/useHover/index.d.ts +2 -0
- package/lib/cjs/useHover/index.js +17 -0
- package/lib/cjs/useLongPress/index.d.ts +4 -0
- package/lib/cjs/useLongPress/index.js +19 -0
- package/lib/cjs/useMediaQuery/index.d.ts +1 -0
- package/lib/cjs/useMediaQuery/index.js +22 -0
- package/lib/cjs/useOnScreen/index.d.ts +2 -0
- package/lib/cjs/useOnScreen/index.js +23 -0
- package/lib/cjs/useOnlineStatus/index.d.ts +1 -0
- package/lib/cjs/useOnlineStatus/index.js +14 -0
- package/lib/cjs/usePagination/index.d.ts +9 -0
- package/lib/cjs/usePagination/index.js +22 -0
- package/lib/cjs/usePrevious/index.d.ts +2 -0
- package/lib/cjs/usePrevious/index.js +13 -0
- package/lib/cjs/useRenderCount/index.d.ts +1 -0
- package/lib/cjs/useRenderCount/index.js +11 -0
- package/lib/cjs/useScript/index.d.ts +2 -0
- package/lib/cjs/useScript/index.js +19 -0
- package/lib/cjs/useSize/index.d.ts +3 -0
- package/lib/cjs/useSize/index.js +18 -0
- package/lib/cjs/useStateWithHistory/index.d.ts +4 -0
- package/lib/cjs/useStateWithHistory/index.js +53 -0
- package/lib/cjs/useStateWithValidation/index.d.ts +2 -0
- package/lib/cjs/useStateWithValidation/index.js +14 -0
- package/lib/cjs/useStorage/index.d.ts +5 -0
- package/lib/cjs/useStorage/index.js +33 -0
- package/lib/cjs/useTimeout/index.d.ts +2 -0
- package/lib/cjs/useTimeout/index.js +26 -0
- package/lib/cjs/useToggle/index.d.ts +2 -0
- package/lib/cjs/useToggle/index.js +12 -0
- package/lib/cjs/useUpdateEffect/index.d.ts +2 -0
- package/lib/cjs/useUpdateEffect/index.js +14 -0
- package/lib/cjs/useWindowSize/index.d.ts +2 -0
- package/lib/cjs/useWindowSize/index.js +18 -0
- package/lib/esm/global.d.d.ts +7 -0
- package/lib/esm/global.d.js +1 -0
- package/lib/esm/index.d.ts +32 -0
- package/lib/esm/index.js +32 -0
- package/lib/esm/useArray/index.d.ts +2 -0
- package/lib/esm/useArray/index.js +40 -0
- package/lib/esm/useAsync/index.d.ts +2 -0
- package/lib/esm/useAsync/index.js +26 -0
- package/lib/esm/useClickOutside/index.d.ts +5 -0
- package/lib/esm/useClickOutside/index.js +8 -0
- package/lib/esm/useCookie/index.d.ts +2 -0
- package/lib/esm/useCookie/index.js +20 -0
- package/lib/esm/useCopyToClipboard/index.d.ts +2 -0
- package/lib/esm/useCopyToClipboard/index.js +14 -0
- package/lib/esm/useDarkMode/index.d.ts +4 -0
- package/lib/esm/useDarkMode/index.js +12 -0
- package/lib/esm/useDebounce/index.d.ts +2 -0
- package/lib/esm/useDebounce/index.js +16 -0
- package/lib/esm/useDebugInformation/index.d.ts +8 -0
- package/lib/esm/useDebugInformation/index.js +38 -0
- package/lib/esm/useDeepCompareEffect/index.d.ts +2 -0
- package/lib/esm/useDeepCompareEffect/index.js +10 -0
- package/lib/esm/useEffectOnce/index.d.ts +1 -0
- package/lib/esm/useEffectOnce/index.js +4 -0
- package/lib/esm/useEventListener/index.d.ts +2 -0
- package/lib/esm/useEventListener/index.js +15 -0
- package/lib/esm/useFetch/index.d.ts +2 -0
- package/lib/esm/useFetch/index.js +76 -0
- package/lib/esm/useGenerateHtmlId/index.d.ts +3 -0
- package/lib/esm/useGenerateHtmlId/index.js +7 -0
- package/lib/esm/useGeolocation/index.d.ts +2 -0
- package/lib/esm/useGeolocation/index.js +23 -0
- package/lib/esm/useHover/index.d.ts +2 -0
- package/lib/esm/useHover/index.js +11 -0
- package/lib/esm/useLongPress/index.d.ts +4 -0
- package/lib/esm/useLongPress/index.js +13 -0
- package/lib/esm/useMediaQuery/index.d.ts +1 -0
- package/lib/esm/useMediaQuery/index.js +16 -0
- package/lib/esm/useOnScreen/index.d.ts +2 -0
- package/lib/esm/useOnScreen/index.js +20 -0
- package/lib/esm/useOnlineStatus/index.d.ts +1 -0
- package/lib/esm/useOnlineStatus/index.js +8 -0
- package/lib/esm/usePagination/index.d.ts +9 -0
- package/lib/esm/usePagination/index.js +19 -0
- package/lib/esm/usePrevious/index.d.ts +2 -0
- package/lib/esm/usePrevious/index.js +10 -0
- package/lib/esm/useRenderCount/index.d.ts +1 -0
- package/lib/esm/useRenderCount/index.js +8 -0
- package/lib/esm/useScript/index.d.ts +2 -0
- package/lib/esm/useScript/index.js +13 -0
- package/lib/esm/useSize/index.d.ts +3 -0
- package/lib/esm/useSize/index.js +15 -0
- package/lib/esm/useStateWithHistory/index.d.ts +4 -0
- package/lib/esm/useStateWithHistory/index.js +50 -0
- package/lib/esm/useStateWithValidation/index.d.ts +2 -0
- package/lib/esm/useStateWithValidation/index.js +11 -0
- package/lib/esm/useStorage/index.d.ts +5 -0
- package/lib/esm/useStorage/index.js +28 -0
- package/lib/esm/useTimeout/index.d.ts +2 -0
- package/lib/esm/useTimeout/index.js +23 -0
- package/lib/esm/useToggle/index.d.ts +2 -0
- package/lib/esm/useToggle/index.js +9 -0
- package/lib/esm/useUpdateEffect/index.d.ts +2 -0
- package/lib/esm/useUpdateEffect/index.js +11 -0
- package/lib/esm/useWindowSize/index.d.ts +2 -0
- package/lib/esm/useWindowSize/index.js +12 -0
- package/package.json +49 -0
@@ -0,0 +1,18 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
var react_1 = require("react");
|
7
|
+
var useMediaQuery_1 = __importDefault(require("../useMediaQuery"));
|
8
|
+
var useStorage_1 = require("../useStorage");
|
9
|
+
function useDarkMode() {
|
10
|
+
var _a = (0, useStorage_1.useLocalStorage)("useDarkMode"), darkMode = _a[0], setDarkMode = _a[1];
|
11
|
+
var prefersDarkMode = (0, useMediaQuery_1.default)("(prefers-color-scheme: dark)");
|
12
|
+
var enabled = darkMode !== null && darkMode !== void 0 ? darkMode : prefersDarkMode;
|
13
|
+
(0, react_1.useEffect)(function () {
|
14
|
+
document.body.classList.toggle("dark-mode", enabled);
|
15
|
+
}, [enabled]);
|
16
|
+
return [enabled, setDarkMode];
|
17
|
+
}
|
18
|
+
exports.default = useDarkMode;
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
3
|
+
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
4
|
+
if (ar || !(i in from)) {
|
5
|
+
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
6
|
+
ar[i] = from[i];
|
7
|
+
}
|
8
|
+
}
|
9
|
+
return to.concat(ar || Array.prototype.slice.call(from));
|
10
|
+
};
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
13
|
+
};
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
15
|
+
var react_1 = require("react");
|
16
|
+
var useTimeout_1 = __importDefault(require("../useTimeout"));
|
17
|
+
function useDebounce(callback, delay, dependencies) {
|
18
|
+
var _a = (0, useTimeout_1.default)(callback, delay), reset = _a.reset, clear = _a.clear;
|
19
|
+
(0, react_1.useEffect)(reset, __spreadArray(__spreadArray([], dependencies, true), [reset], false));
|
20
|
+
(0, react_1.useEffect)(clear, [clear]);
|
21
|
+
}
|
22
|
+
exports.default = useDebounce;
|
@@ -0,0 +1,8 @@
|
|
1
|
+
interface DebugInformation {
|
2
|
+
count: number;
|
3
|
+
changedProps: Record<string, unknown>;
|
4
|
+
timeSinceLastRender: number;
|
5
|
+
lastRenderTimestamp: number;
|
6
|
+
}
|
7
|
+
export default function useDebugInformation(componentName: string, props: Record<string, unknown>): DebugInformation;
|
8
|
+
export {};
|
@@ -0,0 +1,44 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
3
|
+
__assign = Object.assign || function(t) {
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
5
|
+
s = arguments[i];
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
7
|
+
t[p] = s[p];
|
8
|
+
}
|
9
|
+
return t;
|
10
|
+
};
|
11
|
+
return __assign.apply(this, arguments);
|
12
|
+
};
|
13
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
14
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
var react_1 = require("react");
|
18
|
+
var useRenderCount_1 = __importDefault(require("../useRenderCount"));
|
19
|
+
function useDebugInformation(componentName, props) {
|
20
|
+
var count = (0, useRenderCount_1.default)();
|
21
|
+
var changedProps = (0, react_1.useRef)({});
|
22
|
+
var previousProps = (0, react_1.useRef)(props);
|
23
|
+
var lastRenderTimestamp = (0, react_1.useRef)(Date.now());
|
24
|
+
var propKeys = Object.keys(__assign(__assign({}, props), previousProps));
|
25
|
+
changedProps.current = propKeys.reduce(function (obj, key) {
|
26
|
+
var _a;
|
27
|
+
if (props[key] === previousProps.current[key])
|
28
|
+
return obj;
|
29
|
+
return __assign(__assign({}, obj), (_a = {}, _a[key] = { previous: previousProps.current[key], current: props[key] }, _a));
|
30
|
+
}, {});
|
31
|
+
var info = {
|
32
|
+
count: count,
|
33
|
+
changedProps: changedProps.current,
|
34
|
+
timeSinceLastRender: Date.now() - lastRenderTimestamp.current,
|
35
|
+
lastRenderTimestamp: lastRenderTimestamp.current,
|
36
|
+
};
|
37
|
+
(0, react_1.useEffect)(function () {
|
38
|
+
previousProps.current = props;
|
39
|
+
lastRenderTimestamp.current = Date.now();
|
40
|
+
console.log("[debug-info]", componentName, info);
|
41
|
+
});
|
42
|
+
return info;
|
43
|
+
}
|
44
|
+
exports.default = useDebugInformation;
|
@@ -0,0 +1,16 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
var react_1 = require("react");
|
7
|
+
var isEqual_1 = __importDefault(require("lodash/fp/isEqual"));
|
8
|
+
function useDeepCompareEffect(callback, dependencies) {
|
9
|
+
if (dependencies === void 0) { dependencies = []; }
|
10
|
+
var currentDependenciesRef = (0, react_1.useRef)([]);
|
11
|
+
if (!(0, isEqual_1.default)(currentDependenciesRef.current, dependencies)) {
|
12
|
+
currentDependenciesRef.current = dependencies;
|
13
|
+
}
|
14
|
+
(0, react_1.useEffect)(callback, [currentDependenciesRef.current]);
|
15
|
+
}
|
16
|
+
exports.default = useDeepCompareEffect;
|
@@ -0,0 +1 @@
|
|
1
|
+
export default function useEffectOnce(callback: () => void): void;
|
@@ -0,0 +1,18 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function useEventListener(eventType, callback, element) {
|
5
|
+
if (element === void 0) { element = window; }
|
6
|
+
var callbackRef = (0, react_1.useRef)(callback);
|
7
|
+
(0, react_1.useEffect)(function () {
|
8
|
+
callbackRef.current = callback;
|
9
|
+
}, [callback]);
|
10
|
+
(0, react_1.useEffect)(function () {
|
11
|
+
if (element == null)
|
12
|
+
return;
|
13
|
+
var handler = function (e) { return callbackRef.current(e); };
|
14
|
+
element.addEventListener(eventType, handler);
|
15
|
+
return function () { return element.removeEventListener(eventType, handler); };
|
16
|
+
}, [eventType, element]);
|
17
|
+
}
|
18
|
+
exports.default = useEventListener;
|
@@ -0,0 +1,82 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
3
|
+
__assign = Object.assign || function(t) {
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
5
|
+
s = arguments[i];
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
7
|
+
t[p] = s[p];
|
8
|
+
}
|
9
|
+
return t;
|
10
|
+
};
|
11
|
+
return __assign.apply(this, arguments);
|
12
|
+
};
|
13
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
14
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
15
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
16
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
17
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
18
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
19
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
20
|
+
});
|
21
|
+
};
|
22
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
23
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
24
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
25
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
26
|
+
function step(op) {
|
27
|
+
if (f) throw new TypeError("Generator is already executing.");
|
28
|
+
while (_) try {
|
29
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
30
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
31
|
+
switch (op[0]) {
|
32
|
+
case 0: case 1: t = op; break;
|
33
|
+
case 4: _.label++; return { value: op[1], done: false };
|
34
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
35
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
36
|
+
default:
|
37
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
38
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
39
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
40
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
41
|
+
if (t[2]) _.ops.pop();
|
42
|
+
_.trys.pop(); continue;
|
43
|
+
}
|
44
|
+
op = body.call(thisArg, _);
|
45
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
46
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
47
|
+
}
|
48
|
+
};
|
49
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
50
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
51
|
+
};
|
52
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
53
|
+
var useAsync_1 = __importDefault(require("../useAsync"));
|
54
|
+
var DEFAULT_OPTIONS = {
|
55
|
+
headers: { "Content-Type": "application/json" },
|
56
|
+
};
|
57
|
+
function useFetch(url, options, dependencies) {
|
58
|
+
var _this = this;
|
59
|
+
if (options === void 0) { options = {}; }
|
60
|
+
if (dependencies === void 0) { dependencies = []; }
|
61
|
+
return (0, useAsync_1.default)(function () { return __awaiter(_this, void 0, void 0, function () {
|
62
|
+
var _this = this;
|
63
|
+
return __generator(this, function (_a) {
|
64
|
+
return [2 /*return*/, fetch(url, __assign(__assign({}, DEFAULT_OPTIONS), options)).then(function (res) { return __awaiter(_this, void 0, void 0, function () {
|
65
|
+
var json;
|
66
|
+
return __generator(this, function (_a) {
|
67
|
+
switch (_a.label) {
|
68
|
+
case 0:
|
69
|
+
if (res.ok)
|
70
|
+
return [2 /*return*/, res.json()];
|
71
|
+
return [4 /*yield*/, res.json()];
|
72
|
+
case 1:
|
73
|
+
json = _a.sent();
|
74
|
+
return [4 /*yield*/, Promise.reject(json)];
|
75
|
+
case 2: return [2 /*return*/, _a.sent()];
|
76
|
+
}
|
77
|
+
});
|
78
|
+
}); })];
|
79
|
+
});
|
80
|
+
}); }, dependencies);
|
81
|
+
}
|
82
|
+
exports.default = useFetch;
|
@@ -0,0 +1,9 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
var counter = 0;
|
5
|
+
var useGenerateHtmlId = function () {
|
6
|
+
var id = (0, react_1.useMemo)(function () { return ++counter; }, []);
|
7
|
+
return function (suffix) { return "id" + id + "_" + suffix; };
|
8
|
+
};
|
9
|
+
exports.default = useGenerateHtmlId;
|
@@ -0,0 +1,26 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function useGeolocation(options) {
|
5
|
+
if (options === void 0) { options = undefined; }
|
6
|
+
var _a = (0, react_1.useState)(true), loading = _a[0], setLoading = _a[1];
|
7
|
+
var _b = (0, react_1.useState)(), error = _b[0], setError = _b[1];
|
8
|
+
var _c = (0, react_1.useState)({}), data = _c[0], setData = _c[1];
|
9
|
+
(0, react_1.useEffect)(function () {
|
10
|
+
var successHandler = function (geoLocation) {
|
11
|
+
console.log("s", geoLocation);
|
12
|
+
setLoading(false);
|
13
|
+
setError(null);
|
14
|
+
setData(geoLocation.coords);
|
15
|
+
};
|
16
|
+
var errorHandler = function (geoLocation) {
|
17
|
+
setError(geoLocation);
|
18
|
+
setLoading(false);
|
19
|
+
};
|
20
|
+
navigator.geolocation.getCurrentPosition(successHandler, errorHandler, options);
|
21
|
+
var id = navigator.geolocation.watchPosition(successHandler, errorHandler, options);
|
22
|
+
return function () { return navigator.geolocation.clearWatch(id); };
|
23
|
+
}, [options]);
|
24
|
+
return { loading: loading, error: error, data: data };
|
25
|
+
}
|
26
|
+
exports.default = useGeolocation;
|
@@ -0,0 +1,17 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
var react_1 = require("react");
|
7
|
+
var useEventListener_1 = __importDefault(require("../useEventListener"));
|
8
|
+
function useHover(ref) {
|
9
|
+
var _a = (0, react_1.useState)(false), hovered = _a[0], setHovered = _a[1];
|
10
|
+
(0, react_1.useEffect)(function () {
|
11
|
+
setHovered(false);
|
12
|
+
}, [ref.current]);
|
13
|
+
(0, useEventListener_1.default)("mouseover", function () { return setHovered(true); }, ref.current);
|
14
|
+
(0, useEventListener_1.default)("mouseout", function () { return setHovered(false); }, ref.current);
|
15
|
+
return hovered;
|
16
|
+
}
|
17
|
+
exports.default = useHover;
|
@@ -0,0 +1,19 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
var useEffectOnce_1 = __importDefault(require("../useEffectOnce"));
|
7
|
+
var useEventListener_1 = __importDefault(require("../useEventListener"));
|
8
|
+
var useTimeout_1 = __importDefault(require("../useTimeout"));
|
9
|
+
function useLongPress(ref, cb, _a) {
|
10
|
+
var _b = _a === void 0 ? {} : _a, _c = _b.delay, delay = _c === void 0 ? 250 : _c;
|
11
|
+
var _d = (0, useTimeout_1.default)(cb, delay), reset = _d.reset, clear = _d.clear;
|
12
|
+
(0, useEffectOnce_1.default)(clear);
|
13
|
+
(0, useEventListener_1.default)("mousedown", reset, ref.current);
|
14
|
+
(0, useEventListener_1.default)("touchstart", reset, ref.current);
|
15
|
+
(0, useEventListener_1.default)("mouseup", clear, ref.current);
|
16
|
+
(0, useEventListener_1.default)("mouseleave", clear, ref.current);
|
17
|
+
(0, useEventListener_1.default)("touchend", clear, ref.current);
|
18
|
+
}
|
19
|
+
exports.default = useLongPress;
|
@@ -0,0 +1 @@
|
|
1
|
+
export default function useMediaQuery(mediaQuery: string): boolean;
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
var react_1 = require("react");
|
7
|
+
var useEventListener_1 = __importDefault(require("../useEventListener"));
|
8
|
+
function useMediaQuery(mediaQuery) {
|
9
|
+
var _a = (0, react_1.useState)(false), isMatch = _a[0], setIsMatch = _a[1];
|
10
|
+
var _b = (0, react_1.useState)(undefined), mediaQueryList = _b[0], setMediaQueryList = _b[1];
|
11
|
+
(0, react_1.useEffect)(function () {
|
12
|
+
var list = window.matchMedia(mediaQuery);
|
13
|
+
setMediaQueryList(list);
|
14
|
+
setIsMatch(list.matches);
|
15
|
+
}, [mediaQuery]);
|
16
|
+
(0, useEventListener_1.default)("change", function (event) {
|
17
|
+
var e = event;
|
18
|
+
setIsMatch(e.matches);
|
19
|
+
}, mediaQueryList);
|
20
|
+
return isMatch;
|
21
|
+
}
|
22
|
+
exports.default = useMediaQuery;
|
@@ -0,0 +1,23 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function useOnScreen(ref, rootMargin) {
|
5
|
+
if (rootMargin === void 0) { rootMargin = "0px"; }
|
6
|
+
var _a = (0, react_1.useState)(false), isVisible = _a[0], setIsVisible = _a[1];
|
7
|
+
(0, react_1.useEffect)(function () {
|
8
|
+
if (ref.current == null)
|
9
|
+
return;
|
10
|
+
var observer = new IntersectionObserver(function (_a) {
|
11
|
+
var entry = _a[0];
|
12
|
+
return setIsVisible(entry.isIntersecting);
|
13
|
+
}, { rootMargin: rootMargin });
|
14
|
+
observer.observe(ref.current);
|
15
|
+
return function () {
|
16
|
+
if (ref.current == null)
|
17
|
+
return;
|
18
|
+
observer.unobserve(ref.current);
|
19
|
+
};
|
20
|
+
}, [ref.current, rootMargin]);
|
21
|
+
return isVisible;
|
22
|
+
}
|
23
|
+
exports.default = useOnScreen;
|
@@ -0,0 +1 @@
|
|
1
|
+
export default function useOnlineStatus(): boolean;
|
@@ -0,0 +1,14 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
var react_1 = require("react");
|
7
|
+
var useEventListener_1 = __importDefault(require("../useEventListener"));
|
8
|
+
function useOnlineStatus() {
|
9
|
+
var _a = (0, react_1.useState)(navigator.onLine), online = _a[0], setOnline = _a[1];
|
10
|
+
(0, useEventListener_1.default)("online", function () { return setOnline(navigator.onLine); });
|
11
|
+
(0, useEventListener_1.default)("offline", function () { return setOnline(navigator.onLine); });
|
12
|
+
return online;
|
13
|
+
}
|
14
|
+
exports.default = useOnlineStatus;
|
@@ -0,0 +1,9 @@
|
|
1
|
+
interface PaginationResponse {
|
2
|
+
data: Record<string, unknown>[];
|
3
|
+
totalPages: number;
|
4
|
+
currentPage: number;
|
5
|
+
nextPage: () => void;
|
6
|
+
previousPage: () => void;
|
7
|
+
}
|
8
|
+
export default function usePagination(data: Record<string, unknown>[], pageSize: number): PaginationResponse;
|
9
|
+
export {};
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function usePagination(data, pageSize) {
|
5
|
+
var _a = (0, react_1.useState)(0), pageIndex = _a[0], setPageIndex = _a[1];
|
6
|
+
var totalPages = Math.ceil(data.length / pageSize);
|
7
|
+
var filteredData = data.slice(pageIndex * pageSize, (pageIndex + 1) * pageSize);
|
8
|
+
var nextPage = function () {
|
9
|
+
setPageIndex(Math.min(pageIndex + 1, totalPages - 1));
|
10
|
+
};
|
11
|
+
var previousPage = function () {
|
12
|
+
setPageIndex(Math.max(pageIndex - 1, 0));
|
13
|
+
};
|
14
|
+
return {
|
15
|
+
data: filteredData,
|
16
|
+
currentPage: pageIndex + 1,
|
17
|
+
totalPages: totalPages,
|
18
|
+
nextPage: nextPage,
|
19
|
+
previousPage: previousPage,
|
20
|
+
};
|
21
|
+
}
|
22
|
+
exports.default = usePagination;
|
@@ -0,0 +1,13 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function usePrevious(value) {
|
5
|
+
var currentRef = (0, react_1.useRef)(value);
|
6
|
+
var previousRef = (0, react_1.useRef)();
|
7
|
+
if (currentRef.current !== value) {
|
8
|
+
previousRef.current = currentRef.current;
|
9
|
+
currentRef.current = value;
|
10
|
+
}
|
11
|
+
return previousRef.current;
|
12
|
+
}
|
13
|
+
exports.default = usePrevious;
|
@@ -0,0 +1 @@
|
|
1
|
+
export default function useRenderCount(): number;
|
@@ -0,0 +1,11 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function useRenderCount() {
|
5
|
+
var count = (0, react_1.useRef)(1);
|
6
|
+
(0, react_1.useEffect)(function () {
|
7
|
+
count.current = count.current + 1;
|
8
|
+
});
|
9
|
+
return count.current;
|
10
|
+
}
|
11
|
+
exports.default = useRenderCount;
|
@@ -0,0 +1,19 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
var useAsync_1 = __importDefault(require("../useAsync"));
|
7
|
+
function useScript(url) {
|
8
|
+
return (0, useAsync_1.default)(function () {
|
9
|
+
var script = document.createElement("script");
|
10
|
+
script.src = url;
|
11
|
+
script.async = true;
|
12
|
+
return new Promise(function (resolve, reject) {
|
13
|
+
script.addEventListener("load", resolve);
|
14
|
+
script.addEventListener("error", reject);
|
15
|
+
document.body.appendChild(script);
|
16
|
+
});
|
17
|
+
}, [url]);
|
18
|
+
}
|
19
|
+
exports.default = useScript;
|
@@ -0,0 +1,18 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function useSize(ref) {
|
5
|
+
var _a = (0, react_1.useState)({}), size = _a[0], setSize = _a[1];
|
6
|
+
(0, react_1.useEffect)(function () {
|
7
|
+
if (ref.current == null)
|
8
|
+
return;
|
9
|
+
var observer = new ResizeObserver(function (_a) {
|
10
|
+
var entry = _a[0];
|
11
|
+
return setSize(entry.contentRect);
|
12
|
+
});
|
13
|
+
observer.observe(ref.current);
|
14
|
+
return function () { return observer.disconnect(); };
|
15
|
+
}, []);
|
16
|
+
return size;
|
17
|
+
}
|
18
|
+
exports.default = useSize;
|
@@ -0,0 +1,53 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function useStateWithHistory(defaultValue, _a) {
|
5
|
+
var _b = _a === void 0 ? {} : _a, _c = _b.capacity, capacity = _c === void 0 ? 10 : _c;
|
6
|
+
var _d = (0, react_1.useState)(defaultValue), value = _d[0], setValue = _d[1];
|
7
|
+
var historyRef = (0, react_1.useRef)([value]);
|
8
|
+
var pointerRef = (0, react_1.useRef)(0);
|
9
|
+
var set = (0, react_1.useCallback)(function (item) {
|
10
|
+
var resolvedValue = typeof item === "function" ? item(value) : item;
|
11
|
+
if (historyRef.current[pointerRef.current] !== resolvedValue) {
|
12
|
+
if (pointerRef.current < historyRef.current.length - 1) {
|
13
|
+
historyRef.current.splice(pointerRef.current + 1);
|
14
|
+
}
|
15
|
+
historyRef.current.push(resolvedValue);
|
16
|
+
while (historyRef.current.length > capacity) {
|
17
|
+
historyRef.current.shift();
|
18
|
+
}
|
19
|
+
pointerRef.current = historyRef.current.length - 1;
|
20
|
+
}
|
21
|
+
setValue(resolvedValue);
|
22
|
+
}, [capacity, value]);
|
23
|
+
var back = (0, react_1.useCallback)(function () {
|
24
|
+
if (pointerRef.current <= 0)
|
25
|
+
return;
|
26
|
+
pointerRef.current--;
|
27
|
+
setValue(historyRef.current[pointerRef.current]);
|
28
|
+
}, []);
|
29
|
+
var forward = (0, react_1.useCallback)(function () {
|
30
|
+
if (pointerRef.current >= historyRef.current.length - 1)
|
31
|
+
return;
|
32
|
+
pointerRef.current++;
|
33
|
+
setValue(historyRef.current[pointerRef.current]);
|
34
|
+
}, []);
|
35
|
+
var go = (0, react_1.useCallback)(function (index) {
|
36
|
+
if (index < 0 || index >= historyRef.current.length - 1)
|
37
|
+
return;
|
38
|
+
pointerRef.current = index;
|
39
|
+
setValue(historyRef.current[pointerRef.current]);
|
40
|
+
}, []);
|
41
|
+
return [
|
42
|
+
value,
|
43
|
+
set,
|
44
|
+
{
|
45
|
+
history: historyRef.current,
|
46
|
+
pointer: pointerRef.current,
|
47
|
+
back: back,
|
48
|
+
forward: forward,
|
49
|
+
go: go,
|
50
|
+
},
|
51
|
+
];
|
52
|
+
}
|
53
|
+
exports.default = useStateWithHistory;
|
@@ -0,0 +1,14 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
var react_1 = require("react");
|
4
|
+
function useStateWithValidation(validationFunc, initialValue) {
|
5
|
+
var _a = (0, react_1.useState)(initialValue), state = _a[0], setState = _a[1];
|
6
|
+
var _b = (0, react_1.useState)(function () { return validationFunc(state); }), isValid = _b[0], setIsValid = _b[1];
|
7
|
+
var onChange = (0, react_1.useCallback)(function (nextState) {
|
8
|
+
var value = typeof nextState === "function" ? nextState(state) : nextState;
|
9
|
+
setState(value);
|
10
|
+
setIsValid(validationFunc(value));
|
11
|
+
}, [validationFunc]);
|
12
|
+
return [state, onChange, isValid];
|
13
|
+
}
|
14
|
+
exports.default = useStateWithValidation;
|
@@ -0,0 +1,5 @@
|
|
1
|
+
import { Dispatch } from "react";
|
2
|
+
declare type StorageObject = [value: any, setValue: Dispatch<unknown>, remove: () => void];
|
3
|
+
export declare function useLocalStorage(key: string, defaultValue?: any): StorageObject;
|
4
|
+
export declare function useSessionStorage(key: string, defaultValue?: any): StorageObject;
|
5
|
+
export {};
|