It would be super exciting if you want to contribute to animate-components
.
To create an animation component, create two new files. For example - newAnimation.js
& styledNewAnimation.js
in src
directory.
Define the keyframes for the animation in styledNewAnimation.js
using styled-components.
// styledNewAnimation.js
import { keyframes } from 'styled-components';
const newAnimation = keyframes`
from {
}
to {
}
`;
export default newAnimation;
The reason we require styledNewAnimation.js
is to isolate the styles from the components. Makes the code readable and easy to test.
Import the high order component present in the animation folder. You can find it here.
Export the component like this,
// newAnimation.js
import { newAnimation } from './styledNewAnimation';
import HOC from '../../containers/HOC'; // High Order Component
export default HOC('NewAnimation', newAnimation); // Creates the component
Note - HOC takes two arguments, one is the name of your component and the other is the keyframe defined for the animation.
If you want to create multiple animation components, create a single object and export it.
// newAnimation.js
import {newAnimation, newAnimationTwo, newAnimationThree } from './styledNewAnimation';
import HOC from '../../containers/HOC';
const newAnimationObj = {
NewAnimation: HOC('NewAnimation', newAnimation),
NewAnimationTwo: HOC('NewAnimationTwo', newAnimationTwo),
NewAnimationThree: HOC('NewAnimationThree', newAnimationThree)
};
export default newAnimationObj;
Add type annotations to your components.
// newAnimation.js
import {newAnimation, newAnimationTwo, newAnimationThree } from './styledNewAnimation';
import HOC from '../../containers/HOC';
import type { Components } from '../../../types';
const newAnimationObj: Components = {
NewAnimation: HOC('NewAnimation', newAnimation),
NewAnimationTwo: HOC('NewAnimationTwo', newAnimationTwo),
NewAnimationThree: HOC('NewAnimationThree', newAnimationThree)
};
export default newAnimationObj;
Run yarn flow
In index.js, import the object or the component created earlier (newAnimation.js
), extract different components from the object if any and then finally export them.
import newAnimationObj from './newAnimation';
const {...components} = newAnimationObj;
export {...components};
Run yarn lint
.
Run yarn webpack:build
There is a small starter kit kit for testing the animations.
// ./starter/App.js
import React, { Component } from 'react';
import { ExpanseDown } from '../index';
export default class App extends Component {
render () {
return (
<ExpanseDown duration="2s">
<h1>Hello World</h1>
</ExpanseDown>
);
}
}
Start the server using yarn start
and you're ready to go.
That's it ! I'm excited to see your pull request.
There's lot to be done. Thanks ❤️