react-sparkle
Advanced tools
Comparing version 0.0.3 to 1.0.0
{ | ||
"name": "react-sparkle", | ||
"version": "0.0.3", | ||
"version": "1.0.0", | ||
"description": "A React component to increase the number of sparkles in your app", | ||
@@ -41,3 +41,4 @@ "homepage": "https://github.com/kmjennison/react-sparkle", | ||
"dependencies": { | ||
"react": "^16.2.0" | ||
"react": "^16.2.0", | ||
"resize-observer-polyfill": "^1.5.0" | ||
}, | ||
@@ -44,0 +45,0 @@ "jest": { |
@@ -5,2 +5,3 @@ /* globals Image */ | ||
import PropTypes from 'prop-types' | ||
import ResizeObserver from 'resize-observer-polyfill' | ||
@@ -50,3 +51,3 @@ const spriteSrc = '' | ||
this.sparkleContext = this.sparkleCanvas.getContext('2d') | ||
this.sizeCanvas() | ||
this.parentResizeObserver() | ||
this.start() | ||
@@ -66,15 +67,27 @@ } | ||
sizeCanvas () { | ||
sizeCanvas (parentWidth, parentHeight) { | ||
const { overflowPx } = this.props | ||
// Get dimensions of parent container | ||
const parentNode = this.sparkleWrapper.parentNode | ||
const parentWidth = parentNode.clientWidth | ||
const parentHeight = parentNode.clientHeight | ||
// Size the canvas | ||
this.sparkleCanvas.width = parentWidth + 2 * overflowPx | ||
this.sparkleCanvas.height = parentHeight + 2 * overflowPx | ||
this.sparkleCanvas.width = parentWidth + (2 * overflowPx) | ||
this.sparkleCanvas.height = parentHeight + (2 * overflowPx) | ||
} | ||
// Resize our canvas when the parent resizes | ||
parentResizeObserver () { | ||
const self = this | ||
const ro = new ResizeObserver((entries, observer) => { | ||
for (const entry of entries) { | ||
const {left, top, width, height} = entry.contentRect | ||
console.log('Element:', entry.target) | ||
console.log(`Element's size: ${width}px x ${height}px`) | ||
console.log(`Element's paddings: ${top}px ; ${left}px`) | ||
self.sizeCanvas(width, height) | ||
} | ||
}) | ||
ro.observe(this.sparkleWrapper.parentNode) | ||
} | ||
randomSparkleSize () { | ||
@@ -117,8 +130,10 @@ const { minSize, maxSize } = this.props | ||
recreateSparkle (existingSparkle) { | ||
const size = this.randomSparkleSize() | ||
return Object.assign(existingSparkle, { | ||
// Subtract size so sparkles don't get cut off by the edge of the canvas | ||
position: { | ||
x: Math.floor(Math.random() * this.sparkleCanvas.width), | ||
y: Math.floor(Math.random() * this.sparkleCanvas.height) | ||
x: Math.floor(Math.random() * (this.sparkleCanvas.width - size)), | ||
y: Math.floor(Math.random() * (this.sparkleCanvas.height - size)) | ||
}, | ||
size: this.randomSparkleSize(), | ||
size: size, | ||
opacity: this.getOpacity(), | ||
@@ -171,3 +186,5 @@ color: this.getColor(), | ||
self.sparkleContext.fillStyle = sparkle.color | ||
self.sparkleContext.fillRect(sparkle.position.x, sparkle.position.y, 7, 7) | ||
self.sparkleContext.fillRect( | ||
sparkle.position.x, sparkle.position.y, | ||
sparkle.size, sparkle.size) | ||
} | ||
@@ -203,3 +220,2 @@ | ||
// Sparkle has faded out | ||
// TODO: fade in new sparkles | ||
if (sparkle.opacity < 0) { | ||
@@ -214,4 +230,2 @@ // Either replace the sparkle with a brand new one or | ||
} | ||
// TODO: change position | ||
}) | ||
@@ -240,3 +254,4 @@ | ||
top: `-${overflowPx}px`, | ||
left: `-${overflowPx}px` | ||
left: `-${overflowPx}px`, | ||
pointerEvents: 'none' | ||
}} | ||
@@ -272,20 +287,40 @@ > | ||
Sparkle.defaultProps = { | ||
// The color of the sparkles. Can be a color, an array of colors, | ||
// or 'random' (which will randomly pick from all hex colors). | ||
color: '#FFF', | ||
count: 50, // number of sparkles | ||
// The number of sparkles to render. A large number could slow | ||
// down the page. | ||
count: 50, | ||
// The minimum and maximum diameter of sparkles, in pixels. | ||
minSize: 5, | ||
maxSize: 8, | ||
// The number of pixels the sparkles should extend beyond the | ||
// bounds of the parent element. | ||
overflowPx: 20, | ||
// 0 to 1000, with 0 never fading sparkles out and 1000 immediately | ||
// removing sparkles; i.e., how quickly new sparkles are created | ||
// How quickly sparkles disappear; in other words, how quickly | ||
// new sparkles are created. Should be between 0 and 1000, | ||
// with 0 never fading sparkles out and 1000 immediately | ||
// removing sparkles. Most meaningful speeds are between | ||
// 0 and 150. | ||
fadeOutSpeed: 50, | ||
// Whether we should create an entirely new sparkle when one fades out. | ||
// If false, we'll just reset the opacity. | ||
// Whether we should create an entirely new sparkle when one | ||
// fades out. If false, we'll just reset the opacity, keeping | ||
// all other attributes of the sparkle the same. | ||
newSparkleOnFadeOut: true, | ||
// Whether sparkles should have a "flickering" effect. | ||
flicker: true, | ||
flickerSpeed: 'normal' // One of: slowest, slower, slow, normal, fast, faster, fastest | ||
// TODO | ||
// movement speed control | ||
// direction toggle? or likelyhood of moving left/right/up/down | ||
// How quickly the "flickering" should happen. | ||
// One of: slowest, slower, slow, normal, fast, faster, fastest | ||
flickerSpeed: 'normal' | ||
} | ||
// Features that would be good to add: | ||
// - Option to fade in new sparkles | ||
// - Sparkle movement | ||
// - "Wandering" movement, as in https://github.com/simeydotme/jQuery-canvas-sparkles | ||
// - Function-based movement likelihood (e.g. gravity-esque behavior) | ||
// - Recreate sparkles when they leave the canvas | ||
// - Larger-sized sparkles that still look good (the existing | ||
// sprites get blurry); possibly use drawn canvas images | ||
// instead of sprites | ||
export default Sparkle |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
Minified code
QualityThis package contains minified code. This may be harmless in some cases where minified code is included in packaged libraries, however packages on npm should not minify code.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
431
0
2
254092
2
+ Addedresize-observer-polyfill@1.5.1(transitive)