Skip to content

Commit 580317e

Browse files
committed
Initial commit
0 parents  commit 580317e

File tree

7 files changed

+488
-0
lines changed

7 files changed

+488
-0
lines changed

.gitattributes

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
# Auto detect text files and perform LF normalization
2+
* text=auto

.gitignore

Lines changed: 127 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,127 @@
1+
# Logs
2+
logs
3+
*.log
4+
npm-debug.log*
5+
yarn-debug.log*
6+
yarn-error.log*
7+
lerna-debug.log*
8+
.pnpm-debug.log*
9+
10+
# Diagnostic reports (https://nodejs.org/api/report.html)
11+
report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
12+
13+
# Runtime data
14+
pids
15+
*.pid
16+
*.seed
17+
*.pid.lock
18+
19+
# Directory for instrumented libs generated by jscoverage/JSCover
20+
lib-cov
21+
22+
# Coverage directory used by tools like istanbul
23+
coverage
24+
*.lcov
25+
26+
# nyc test coverage
27+
.nyc_output
28+
29+
# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
30+
.grunt
31+
32+
# Bower dependency directory (https://bower.io/)
33+
bower_components
34+
35+
# node-waf configuration
36+
.lock-wscript
37+
38+
# Compiled binary addons (https://nodejs.org/api/addons.html)
39+
build/Release
40+
41+
# Dependency directories
42+
node_modules/
43+
jspm_packages/
44+
45+
# Snowpack dependency directory (https://snowpack.dev/)
46+
web_modules/
47+
48+
# TypeScript cache
49+
*.tsbuildinfo
50+
51+
# Optional npm cache directory
52+
.npm
53+
54+
# Optional eslint cache
55+
.eslintcache
56+
57+
# Optional stylelint cache
58+
.stylelintcache
59+
60+
# Microbundle cache
61+
.rpt2_cache/
62+
.rts2_cache_cjs/
63+
.rts2_cache_es/
64+
.rts2_cache_umd/
65+
66+
# Optional REPL history
67+
.node_repl_history
68+
69+
# Output of 'npm pack'
70+
*.tgz
71+
72+
# Yarn Integrity file
73+
.yarn-integrity
74+
75+
# dotenv environment variable files
76+
.env
77+
.env.development.local
78+
.env.test.local
79+
.env.production.local
80+
.env.local
81+
82+
# parcel-bundler cache (https://parceljs.org/)
83+
.cache
84+
.parcel-cache
85+
86+
# Next.js build output
87+
.next
88+
out
89+
90+
# Nuxt.js build / generate output
91+
.nuxt
92+
dist
93+
94+
# Gatsby files
95+
.cache/
96+
# Comment in the public line in if your project uses Gatsby and not Next.js
97+
# https://nextjs.org/blog/next-9-1#public-directory-support
98+
# public
99+
100+
# vuepress build output
101+
.vuepress/dist
102+
103+
# vuepress v2.x temp and cache directory
104+
.temp
105+
.cache
106+
107+
# Serverless directories
108+
.serverless/
109+
110+
# FuseBox cache
111+
.fusebox/
112+
113+
# DynamoDB Local files
114+
.dynamodb/
115+
116+
# TernJS port file
117+
.tern-port
118+
119+
# Stores VSCode versions used for testing VSCode extensions
120+
.vscode-test
121+
122+
# yarn v2
123+
.yarn/cache
124+
.yarn/unplugged
125+
.yarn/build-state.yml
126+
.yarn/install-state.gz
127+
.pnp.*

LICENSE

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
MIT License
2+
3+
Copyright (c) 2022 MAKSS
4+
5+
Permission is hereby granted, free of charge, to any person obtaining a copy
6+
of this software and associated documentation files (the "Software"), to deal
7+
in the Software without restriction, including without limitation the rights
8+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
copies of the Software, and to permit persons to whom the Software is
10+
furnished to do so, subject to the following conditions:
11+
12+
The above copyright notice and this permission notice shall be included in all
13+
copies or substantial portions of the Software.
14+
15+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21+
SOFTWARE.

index.js

Lines changed: 42 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
import { useState, useEffect } from "react";
2+
3+
function useDetectScroll({
4+
thr = 0,
5+
up = "scrolling up",
6+
down = "scrolling down",
7+
}) {
8+
const [scrollDir, setScrollDir] = useState(down);
9+
10+
useEffect(() => {
11+
const threshold = thr;
12+
let lastScrollY = window.pageYOffset;
13+
let ticking = false;
14+
15+
const updateScrollDir = () => {
16+
const scrollY = window.pageYOffset;
17+
18+
if (Math.abs(scrollY - lastScrollY) < threshold) {
19+
ticking = false;
20+
return;
21+
}
22+
setScrollDir(scrollY > lastScrollY ? down : up);
23+
lastScrollY = scrollY > 0 ? scrollY : 0;
24+
ticking = false;
25+
};
26+
27+
const onScroll = () => {
28+
if (!ticking) {
29+
window.requestAnimationFrame(updateScrollDir);
30+
ticking = true;
31+
}
32+
};
33+
34+
window.addEventListener("scroll", onScroll);
35+
36+
return () => window.removeEventListener("scroll", onScroll);
37+
}, [scrollDir]);
38+
39+
return [scrollDir];
40+
}
41+
42+
export default useDetectScroll;

package.json

Lines changed: 43 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
1+
{
2+
"author": "SMAKSS",
3+
"bugs": {
4+
"url": "https://github.com/SMAKSS/react-scroll-direction/issues"
5+
},
6+
"description": "Detect scroll direction in react applications.",
7+
"devDependencies": {
8+
"@rollup/plugin-commonjs": "^23.0.2",
9+
"@rollup/plugin-node-resolve": "^15.0.1",
10+
"react": "^18.2.0",
11+
"rollup": "^3.2.3"
12+
},
13+
"files": [
14+
"dist"
15+
],
16+
"homepage": "https://github.com/SMAKSS/react-scroll-direction#readme",
17+
"keywords": [
18+
"npm",
19+
"yarn",
20+
"react",
21+
"scroll",
22+
"direction",
23+
"SMAKSS",
24+
"CommonJS",
25+
"EcmaScript",
26+
"detect scroll in react",
27+
"react scroll",
28+
"scroll direction"
29+
],
30+
"license": "MIT",
31+
"main": "dist/cjs/index.js",
32+
"module": "dist/esm/index.js",
33+
"name": "@smakss/react-scroll-direction",
34+
"repository": {
35+
"type": "git",
36+
"url": "git+https://github.com/SMAKSS/react-scroll-direction.git"
37+
},
38+
"scripts": {
39+
"generate": "rollup -c"
40+
},
41+
"type": "module",
42+
"version": "0.0.1"
43+
}

rollup.config.js

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
import resolve from "@rollup/plugin-node-resolve";
2+
import commonjs from "@rollup/plugin-commonjs";
3+
import packageJson from "./package.json" assert { type: "json" };
4+
5+
export default [
6+
{
7+
input: "./index.js",
8+
output: [
9+
{
10+
file: packageJson.main,
11+
format: "cjs",
12+
sourcemap: true,
13+
},
14+
{
15+
file: packageJson.module,
16+
format: "esm",
17+
sourcemap: true,
18+
},
19+
],
20+
plugins: [resolve(), commonjs()],
21+
},
22+
];

0 commit comments

Comments
 (0)