npm-pkg-hook 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.babelrc +14 -0
- package/.eslintrc.json +108 -0
- package/README.md +1 -0
- package/jsconfig.json +28 -0
- package/next.config.js +129 -0
- package/package.json +26 -4
- package/src/cookies/index.ts +3 -0
- package/src/hooks/index.js +15 -0
- package/src/hooks/useAcumulateDate/index.js +16 -0
- package/src/hooks/useAnimationText/index.jsx +30 -0
- package/src/hooks/useCategoryStore/index.js +7 -0
- package/src/hooks/useCategoryStore/queries.js +16 -0
- package/src/hooks/useDrag/index.js +57 -0
- package/src/hooks/useEvent/index.js +33 -0
- package/src/hooks/useFetchJson/index.js +25 -0
- package/src/hooks/useFetchMoreInteractions/index.jsx +35 -0
- package/src/hooks/useFormTools/index.js +71 -0
- package/src/hooks/useFullScreenMode/index.js +66 -0
- package/src/hooks/useGetCategorieStore/index.js +21 -0
- package/src/hooks/useGetCategorieStore/queries.js +78 -0
- package/src/hooks/useHover/index.js +29 -0
- package/src/hooks/useInnerHtml/index.js +38 -0
- package/src/hooks/useIntersection/index.js +31 -0
- package/src/hooks/useKeypress/index.js +28 -0
- package/src/hooks/useLocalSorage/index.js +36 -0
- package/src/hooks/useLocationNavigate/index.js +54 -0
- package/src/hooks/useRestaurant/index.js +19 -0
- package/src/hooks/useRestaurant/queries.js +70 -0
- package/src/hooks/useSetState/index.js +24 -0
- package/src/hooks/useTimeAgo/useTimeAgo.js +39 -0
- package/src/hooks/useUpdateCart/index.js +123 -0
- package/src/hooks/useUser/index.js +3 -0
- package/src/hooks/useWindowSize/index.js +38 -0
- package/src/index.jsx +1 -6
- package/src/utils/index.js +27 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { useState, useEffect } from 'react';
|
|
2
|
+
|
|
3
|
+
export default function useWindowSize() {
|
|
4
|
+
// Initialize state with undefined width/height so server and client renders match
|
|
5
|
+
// Learn more here: https://joshwcomeau.com/react/the-perils-of-rehydration/
|
|
6
|
+
const [windowSize, setWindowSize] = useState({
|
|
7
|
+
width: undefined,
|
|
8
|
+
height: undefined
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
// Handler to call on window resize
|
|
13
|
+
function handleResize() {
|
|
14
|
+
// Set window width/height to state
|
|
15
|
+
setWindowSize({
|
|
16
|
+
width: window.innerWidth,
|
|
17
|
+
height: window.innerHeight
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
// Add event listener
|
|
22
|
+
window.addEventListener('resize', handleResize);
|
|
23
|
+
|
|
24
|
+
// Call handler right away so state gets updated with initial window size
|
|
25
|
+
handleResize();
|
|
26
|
+
|
|
27
|
+
// Remove event listener on cleanup
|
|
28
|
+
return () => window.removeEventListener('resize', handleResize);
|
|
29
|
+
}, []); // Empty array ensures that effect is only run on mount
|
|
30
|
+
|
|
31
|
+
return windowSize;
|
|
32
|
+
}
|
|
33
|
+
// Como se usa
|
|
34
|
+
|
|
35
|
+
// 1 -const size = useWindowSize();
|
|
36
|
+
// 2 <div>
|
|
37
|
+
// {size.width}px / {size.height}px
|
|
38
|
+
// </div>
|
package/src/index.jsx
CHANGED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description It takes an array of elements and returns an object with a submit hook for each element.
|
|
3
|
+
* @version 0.1.1
|
|
4
|
+
* @param {array} elements elementos del formulario
|
|
5
|
+
* @return {array} devuelve un array de booleanos con el nombre identificador para cada estado en react.
|
|
6
|
+
*/
|
|
7
|
+
export const validationSubmitHooks = elements => {
|
|
8
|
+
let errorForm = {}
|
|
9
|
+
for (const element of elements) {
|
|
10
|
+
if (element.name) {
|
|
11
|
+
if (element.type === 'text' || element.type === 'password' || element.type === 'email' || element.type === 'number' || element.type === 'hidden') {
|
|
12
|
+
if (element.dataset.required === 'true') {
|
|
13
|
+
if (!element.value) errorForm = { ...errorForm, [element.name]: !element.value }
|
|
14
|
+
else errorForm = { ...errorForm, [element.name]: !element.value }
|
|
15
|
+
} else {
|
|
16
|
+
errorForm = { ...errorForm, [element.name]: false }
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return errorForm
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export const getCurrentDomain = () => {
|
|
25
|
+
return typeof window !== 'undefined' && window.location.hostname.split('.').slice(-2).join('.')
|
|
26
|
+
}
|
|
27
|
+
|