3.1.0 • Published 1 year ago

react-adobe-animate v3.1.0

Weekly downloads
117
License
MIT
Repository
github
Last release
1 year ago

npm npm npm Snyk Vulnerabilities for GitHub Repo semantic-release Commitizen friendly

The component for embedding animations from Adobe Animate.

Installation

npm install react-adobe-animate
# or
yarn add react-adobe-animate

Examples

Dependencies

  • React
  • CreateJS – add this to your page <script src="https://code.createjs.com/1.0.0/createjs.min.js"></script>
  • Your animation – add .js file exported from Adobe Animate to page with <script> tag

How to use

index.html

In your index.html file you should import CreateJS and any other animation js file. Note that this should be done before import of your main jsx file to ensure that they are loaded before React script is executed.

<!DOCTYPE html>
<html lang="en">
  <head>
    <title>React Adobe Animate example</title>
  </head>
  <body>
    <div id="root"></div>
    <script src="https://code.createjs.com/1.0.0/createjs.min.js" type="text/javascript"></script>
    <script src="./lishtml5-with-background.js" type="text/javascript"></script>
    <script src="./lishtml5.js" type="text/javascript"></script>
    <script src="/src/your-main-react-file.jsx"></script>
  </body>
</html>

App.tsx

react-adobe-animate exposes a AnimateCC component used to render the animation. For more details on the props passed to the component please see Props.

import { useState } from "react";
import { AnimateCC, GetAnimationObjectParameter } from "react-adobe-animate";

const App = () => {
  const [paused, setPaused] = useState(true);
  const [animationObject, getAnimationObject] = useState<GetAnimationObjectParameter|null>(null);
  const onClick = () => setPaused(!paused);

  console.log(animationObject);

  return (
    <div style={{ width: "400px" }}>
      <AnimateCC
        animationName="lishtml5"
        getAnimationObject={getAnimationObject}
        paused={paused}
      />

      <AnimateCC
        animationName="lishtml5"
        composition="C1475B64B160904BB90B34246A5FF54B"
        paused={paused}
      />

      <button onClick={onClick}>{paused ? "Unpause" : "Pause"}</button><br />
    </div>
  );
};

Next.js

To use the component with Next.js you have to include CreateJS and Animate files (you have to put those into public folder first) with the Script component.

For detailed example see examples/next/pages/index.tsx.

Props

Prop nameTypeRequiredDescription
animationNamestringtrueName of animation (exportRoot = new lib.animationName(); in js file. There the name is (lib.animationName = function. Also usually name of published file)
compositionstringfalseIf you have two animations with same name you can specify an id of that animation. You can get it from .html file generate by Adobe Animate (var comp=AdobeAn.getComposition("C1475B64B160904BB90B34246A5FF54B");)
getAnimationObjectfunctionfalseIt is fired after component was mounted. It takes 1 argument – animation object that enables you to fire functions created in Adobe Animate
pausedbooleanfalseWhether an animation should be paused
onErrorfunctionfalseFunction called whenever an error is thrown inside the component

All other props will be passed to div surrounding canvas

FAQ

How do I insert animations published from the same file?

Unfortunately it isn't possible to export from Adobe Animate two unique animations. However you can make one! Simply replace all occurrences of composition id inside your .js file of an animation to one created by you. Composition id is this long string in var comp=AdobeAn.getComposition("C1475B64B160904BB90B34246A5FF54B"); found in .html file published by Adobe Animate.

🙋‍♂️ Questions

Should you have any questions on how to use/setup the component feel free to ask you questions on the discussions page.

🤝 Contributing

Contributions, issues and feature requests are welcome!\ Feel free to check issues page.

For development purposes you can use the examples folder. \ You'll find instructions on how to use it in examples/README.md

Show your support

Give a ⭐️ if this project helped you!

📝 License

Copyright © 2019-2022 bibixx bartosz+a.github@legiec.io. This project is MIT licensed.

3.1.0

1 year ago

3.0.1

2 years ago

3.0.0

2 years ago

2.5.0

3 years ago

2.4.0

3 years ago

2.3.1

3 years ago

2.3.0

3 years ago

2.2.3

3 years ago

2.2.2

4 years ago

2.2.1

5 years ago

2.2.0

5 years ago

2.1.9

5 years ago

2.2.0-beta.0

5 years ago

2.1.8

5 years ago

2.1.7

5 years ago

2.1.6

5 years ago

2.1.5

5 years ago

2.1.4

5 years ago

2.1.3

6 years ago

2.1.2

6 years ago

2.1.1

6 years ago

2.1.0

6 years ago

2.0.2

6 years ago

2.0.1

6 years ago

2.0.0

6 years ago

1.0.5

6 years ago

1.0.4

6 years ago

1.0.3

6 years ago

1.0.2

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago