mirror of
https://github.com/brianlovin/security-checklist.git
synced 2026-03-11 08:55:31 +00:00
First try (doesn't work)
This commit is contained in:
parent
12ce3591ce
commit
ced5968aff
2 changed files with 154 additions and 0 deletions
144
components/Header/Confetti.js
Normal file
144
components/Header/Confetti.js
Normal file
|
|
@ -0,0 +1,144 @@
|
|||
// @flow
|
||||
import React, { useState, useRef, useEffect } from 'react';
|
||||
import ReactDOM from 'react-dom';
|
||||
import styled from 'styled-components';
|
||||
|
||||
const ConfettiZone = styled.div`
|
||||
.particles {
|
||||
position: fixed;
|
||||
top: 0;
|
||||
|
||||
.particle {
|
||||
position: absolute;
|
||||
transition: all 5s ease-out;
|
||||
}
|
||||
}
|
||||
`
|
||||
|
||||
const COLORS = ['#2ecc71','#3498db','#e67e22','#e67e22','#e74c3c'];
|
||||
const TOP_OFFSET = typeof window !== 'undefined' && window.innerHeight;
|
||||
const INNER_WIDTH = typeof window !== 'undefined' && window.innerWidth;
|
||||
const LEFT_OFFSET = 250;
|
||||
|
||||
const generateWholeNumber = (min, max) => min + Math.floor(Math.random()*(max - min));
|
||||
|
||||
const generateRandomColor = () => COLORS[generateWholeNumber(0,COLORS.length)];
|
||||
|
||||
export function CircularParticle(props: Props) {
|
||||
const currentConfetti = useRef(null);
|
||||
|
||||
const SIZE_RANGE = [5, 10];
|
||||
const ROTATION_RANGE = [0, 45];
|
||||
|
||||
const size = generateWholeNumber(...SIZE_RANGE);
|
||||
style = {
|
||||
backgroundColor: generateRandomColor(),
|
||||
width: size,
|
||||
height: size,
|
||||
borderRadius: size,
|
||||
transform: `rotateZ(${generateWholeNumber(...ROTATION_RANGE)}deg)`,
|
||||
left: generateWholeNumber(0, INNER_WIDTH),
|
||||
top: generateWholeNumber(-TOP_OFFSET, 0)
|
||||
};
|
||||
|
||||
const {left} = style;
|
||||
|
||||
setTimeout(() => {
|
||||
const node = ReactDOM.findDOMNode(currentConfetti);
|
||||
node.style.top = TOP_OFFSET + generateWholeNumber(0, TOP_OFFSET) + 'px';
|
||||
node.style.left = left + generateWholeNumber(-LEFT_OFFSET, LEFT_OFFSET) + 'px';
|
||||
},0);
|
||||
|
||||
|
||||
return (
|
||||
<div ref={currentConfetti} className='particle' style={this.style}/>
|
||||
);
|
||||
}
|
||||
|
||||
// function SquiggleParticle(props: Props) {
|
||||
|
||||
// static SIZE_RANGE = [15, 45];
|
||||
// static ROTATION_RANGE = [-15, 15];
|
||||
|
||||
// const size = generateWholeNumber(...SquiggleParticle.SIZE_RANGE);
|
||||
// this.style = {
|
||||
// fill: generateRandomColor(),
|
||||
// width: size,
|
||||
// height: size,
|
||||
// transform: `rotateZ(${generateWholeNumber(...SquiggleParticle.ROTATION_RANGE)}deg)`,
|
||||
// left: generateWholeNumber(0, window.innerWidth),
|
||||
// top: generateWholeNumber(-TOP_OFFSET, 0)
|
||||
// };
|
||||
|
||||
// useEffect(() => {
|
||||
// const {left} = this.style;
|
||||
// const {ROTATION_RANGE} = SquiggleParticle;
|
||||
// setTimeout(() => {
|
||||
// const node = ReactDOM.findDOMNode(this.ref);
|
||||
// node.style.top = window.innerHeight + generateWholeNumber(0, TOP_OFFSET) + 'px';
|
||||
// node.style.left = left + generateWholeNumber(-LEFT_OFFSET, LEFT_OFFSET) + 'px';
|
||||
// node.style.transform = `rotateZ(${generateWholeNumber(...ROTATION_RANGE)}deg)`;
|
||||
// },0);
|
||||
// }
|
||||
|
||||
// return (
|
||||
// <svg
|
||||
// ref={ref => this.ref = ref}
|
||||
// className='particle'
|
||||
// style={this.style}
|
||||
// xmlns="http://www.w3.org/2000/svg"
|
||||
// viewBox="0 0 512 512">
|
||||
// <path fill={this.style.fill} d="M428.127,0l-12.716,10.062l12.718-10.06c8.785,11.101,19.716,24.917,19.716,51.051 s-10.932,39.951-19.716,51.053c-7.382,9.331-12.716,16.072-12.716,30.927c0,14.854,5.334,21.594,12.716,30.925 c8.784,11.101,19.716,24.917,19.716,51.05c0,26.135-10.931,39.949-19.715,51.051c-7.383,9.331-12.717,16.072-12.717,30.927 c0,14.855,5.332,21.593,12.711,30.919l-25.435,20.124c-8.781-11.097-19.708-24.909-19.708-51.042 c0-26.135,10.931-39.949,19.715-51.051c7.383-9.331,12.717-16.072,12.717-30.927c0-14.855-5.335-21.595-12.717-30.926 c-8.784-11.101-19.715-24.916-19.715-51.049s10.931-39.95,19.715-51.051c7.383-9.331,12.717-16.072,12.717-30.928 c0-14.855-5.335-21.596-12.718-30.927L428.127,0z"/>
|
||||
// </svg>
|
||||
// );
|
||||
// }
|
||||
|
||||
export function Particles(props: Props) {
|
||||
let {count: n} = props;
|
||||
const particles = [];
|
||||
// const types = [SquiggleParticle, CircularParticle, CircularParticle];
|
||||
const types = [CircularParticle];
|
||||
|
||||
while(n--) {
|
||||
const Particle = types[generateWholeNumber(0,3)];
|
||||
particles.push(
|
||||
<Particle key={n}/>
|
||||
);
|
||||
}
|
||||
|
||||
return (
|
||||
<div className='particles'>
|
||||
{particles}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
export default function Confetti(props: Props) {
|
||||
const [particles, setParticles] = useState([]);
|
||||
|
||||
var id = 1;
|
||||
|
||||
function clean(id) {
|
||||
setParticles(particles.filter(_id => _id !== id))
|
||||
}
|
||||
|
||||
useEffect(() => {
|
||||
id = id;
|
||||
id++;
|
||||
|
||||
setParticles([...particles, id])
|
||||
|
||||
setTimeout(() => {
|
||||
clean(id);
|
||||
}, 5000);
|
||||
});
|
||||
|
||||
return (
|
||||
<ConfettiZone>
|
||||
{particles.map(id => (
|
||||
<Particles key={id} count={Math.floor(INNER_WIDTH / 20)}/>
|
||||
))}
|
||||
</ConfettiZone>
|
||||
);
|
||||
}
|
||||
|
|
@ -10,6 +10,7 @@ import {
|
|||
ProgressBar } from './style';
|
||||
import { PrimaryButton, GhostButton } from '../Button';
|
||||
import Logo from './Logo';
|
||||
import Confetti from './Confetti';
|
||||
|
||||
type Props = {
|
||||
showHeaderShadow: boolean,
|
||||
|
|
@ -21,6 +22,12 @@ type Props = {
|
|||
export default function Header(props: Props) {
|
||||
const { showHeaderShadow, totalItemsCount, currentCount, displayProgress } = props;
|
||||
|
||||
const getConfetti = () => {
|
||||
if (currentCount === totalItemsCount) {
|
||||
return (<Confetti />);
|
||||
}
|
||||
};
|
||||
|
||||
return (
|
||||
<Container showHeaderShadow={showHeaderShadow} data-cy="header">
|
||||
<div>
|
||||
|
|
@ -33,7 +40,10 @@ export default function Header(props: Props) {
|
|||
</div>
|
||||
|
||||
<Progression isHidden={!displayProgress}>
|
||||
{ currentCount === totalItemsCount && `🎉 `}
|
||||
{currentCount} of {totalItemsCount} completed
|
||||
{ currentCount === totalItemsCount && ` 🎉`}
|
||||
{ getConfetti() }
|
||||
<ProgressBar />
|
||||
</Progression>
|
||||
|
||||
|
|
|
|||
Loading…
Reference in a new issue