@lumen5/lottie-web 5.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (300) hide show
  1. package/.babelrc.json +3 -0
  2. package/.eslintrc.json +46 -0
  3. package/.gitattributes +1 -0
  4. package/.github/FUNDING.yml +1 -0
  5. package/.github/ISSUE_TEMPLATE.md +22 -0
  6. package/.github/workflows/publish.yml +26 -0
  7. package/.github/workflows/testAnimations.yml +29 -0
  8. package/.github/workflows/updateScreenshots.yml +34 -0
  9. package/CHANGELOG.md +601 -0
  10. package/History.md +1230 -0
  11. package/LICENSE.md +21 -0
  12. package/README.md +351 -0
  13. package/bower.json +31 -0
  14. package/build/old_parser/bodymovin_parser.jsx +3023 -0
  15. package/build/old_parser/helperProject.aep +0 -0
  16. package/build/player/cjs/lottie.min.js +18229 -0
  17. package/build/player/cjs/lottie_canvas.min.js +16465 -0
  18. package/build/player/cjs/lottie_html.min.js +16312 -0
  19. package/build/player/cjs/lottie_light.min.js +11584 -0
  20. package/build/player/cjs/lottie_light_canvas.min.js +13518 -0
  21. package/build/player/cjs/lottie_light_html.min.js +12843 -0
  22. package/build/player/cjs/lottie_svg.min.js +15053 -0
  23. package/build/player/esm/lottie.min.js +18225 -0
  24. package/build/player/esm/lottie_canvas.min.js +16461 -0
  25. package/build/player/esm/lottie_html.min.js +16308 -0
  26. package/build/player/esm/lottie_light.min.js +11580 -0
  27. package/build/player/esm/lottie_light_canvas.min.js +13514 -0
  28. package/build/player/esm/lottie_light_html.min.js +12839 -0
  29. package/build/player/esm/lottie_svg.min.js +15049 -0
  30. package/build/player/lottie.d.ts +5 -0
  31. package/build/player/lottie.js +17151 -0
  32. package/build/player/lottie.min.js +1 -0
  33. package/build/player/lottie_canvas.js +15506 -0
  34. package/build/player/lottie_canvas.min.js +1 -0
  35. package/build/player/lottie_canvas_worker.js +18196 -0
  36. package/build/player/lottie_canvas_worker.min.js +15 -0
  37. package/build/player/lottie_html.d.ts +5 -0
  38. package/build/player/lottie_html.js +15354 -0
  39. package/build/player/lottie_html.min.js +1 -0
  40. package/build/player/lottie_light.d.ts +5 -0
  41. package/build/player/lottie_light.js +10854 -0
  42. package/build/player/lottie_light.min.js +1 -0
  43. package/build/player/lottie_light_canvas.d.ts +5 -0
  44. package/build/player/lottie_light_canvas.js +12666 -0
  45. package/build/player/lottie_light_canvas.min.js +1 -0
  46. package/build/player/lottie_light_html.d.ts +5 -0
  47. package/build/player/lottie_light_html.js +12029 -0
  48. package/build/player/lottie_light_html.min.js +1 -0
  49. package/build/player/lottie_svg.d.ts +5 -0
  50. package/build/player/lottie_svg.js +14179 -0
  51. package/build/player/lottie_svg.min.js +1 -0
  52. package/build/player/lottie_worker.js +18196 -0
  53. package/build/player/lottie_worker.min.js +15 -0
  54. package/docs/json/animation.json +101 -0
  55. package/docs/json/effects/angle.json +40 -0
  56. package/docs/json/effects/checkBox.json +40 -0
  57. package/docs/json/effects/color.json +40 -0
  58. package/docs/json/effects/customValue.json +4 -0
  59. package/docs/json/effects/dropDown.json +40 -0
  60. package/docs/json/effects/fill.json +55 -0
  61. package/docs/json/effects/group.json +41 -0
  62. package/docs/json/effects/index.json +51 -0
  63. package/docs/json/effects/layer.json +33 -0
  64. package/docs/json/effects/noValue.json +1 -0
  65. package/docs/json/effects/point.json +43 -0
  66. package/docs/json/effects/proLevels.json +130 -0
  67. package/docs/json/effects/slider.json +40 -0
  68. package/docs/json/effects/stroke.json +64 -0
  69. package/docs/json/effects/tint.json +43 -0
  70. package/docs/json/effects/tritone.json +46 -0
  71. package/docs/json/helpers/blendMode.json +71 -0
  72. package/docs/json/helpers/boolean.json +14 -0
  73. package/docs/json/helpers/composite.json +15 -0
  74. package/docs/json/helpers/lineCap.json +19 -0
  75. package/docs/json/helpers/lineJoin.json +19 -0
  76. package/docs/json/helpers/mask.json +80 -0
  77. package/docs/json/helpers/textBased.json +23 -0
  78. package/docs/json/helpers/textGrouping.json +23 -0
  79. package/docs/json/helpers/textShape.json +31 -0
  80. package/docs/json/helpers/transform.json +146 -0
  81. package/docs/json/layers/image.json +113 -0
  82. package/docs/json/layers/null.json +87 -0
  83. package/docs/json/layers/preComp.json +118 -0
  84. package/docs/json/layers/shape.json +157 -0
  85. package/docs/json/layers/solid.json +120 -0
  86. package/docs/json/layers/text.json +523 -0
  87. package/docs/json/properties/doubleKeyframe.json +50 -0
  88. package/docs/json/properties/multiDimensional.json +21 -0
  89. package/docs/json/properties/multiDimensionalKeyframed.json +35 -0
  90. package/docs/json/properties/offsetKeyframe.json +53 -0
  91. package/docs/json/properties/shape.json +27 -0
  92. package/docs/json/properties/shapeKeyframed.json +35 -0
  93. package/docs/json/properties/shapeProp.json +50 -0
  94. package/docs/json/properties/shapePropKeyframe.json +54 -0
  95. package/docs/json/properties/value.json +21 -0
  96. package/docs/json/properties/valueKeyframe.json +33 -0
  97. package/docs/json/properties/valueKeyframed.json +25 -0
  98. package/docs/json/shapes/ellipse.json +54 -0
  99. package/docs/json/shapes/fill.json +48 -0
  100. package/docs/json/shapes/gFill.json +107 -0
  101. package/docs/json/shapes/gStroke.json +137 -0
  102. package/docs/json/shapes/group.json +89 -0
  103. package/docs/json/shapes/merge.json +27 -0
  104. package/docs/json/shapes/rect.json +66 -0
  105. package/docs/json/shapes/repeater.json +63 -0
  106. package/docs/json/shapes/round.json +35 -0
  107. package/docs/json/shapes/shape.json +40 -0
  108. package/docs/json/shapes/star.json +133 -0
  109. package/docs/json/shapes/stroke.json +78 -0
  110. package/docs/json/shapes/transform.json +102 -0
  111. package/docs/json/shapes/trim.json +61 -0
  112. package/docs/json/sources/chars.json +61 -0
  113. package/docs/json/sources/image.json +31 -0
  114. package/docs/json/sources/precomp.json +39 -0
  115. package/index.d.ts +197 -0
  116. package/package.json +54 -0
  117. package/player/index.html +115 -0
  118. package/player/js/3rd_party/BezierEaser.js +158 -0
  119. package/player/js/3rd_party/howler.js +5 -0
  120. package/player/js/3rd_party/seedrandom.js +237 -0
  121. package/player/js/3rd_party/transformation-matrix.js +449 -0
  122. package/player/js/EffectsManager.js +83 -0
  123. package/player/js/animation/AnimationItem.js +809 -0
  124. package/player/js/animation/AnimationItemWorkerOverride.js +157 -0
  125. package/player/js/animation/AnimationManager.js +248 -0
  126. package/player/js/animation/AnimationManagerWorkerOverride.js +201 -0
  127. package/player/js/effects/EffectsManagerPlaceholder.js +5 -0
  128. package/player/js/effects/SliderEffect.js +37 -0
  129. package/player/js/effects/TransformEffect.js +44 -0
  130. package/player/js/elements/AudioElement.js +102 -0
  131. package/player/js/elements/BaseElement.js +78 -0
  132. package/player/js/elements/BaseTextElement.js +4 -0
  133. package/player/js/elements/CompElement.js +107 -0
  134. package/player/js/elements/FootageElement.js +47 -0
  135. package/player/js/elements/ImageElement.js +42 -0
  136. package/player/js/elements/NullElement.js +39 -0
  137. package/player/js/elements/ShapeElement.js +76 -0
  138. package/player/js/elements/SolidElement.js +23 -0
  139. package/player/js/elements/TextElement.js +94 -0
  140. package/player/js/elements/canvasElements/CVBaseElement.js +167 -0
  141. package/player/js/elements/canvasElements/CVCompBaseElement.js +11 -0
  142. package/player/js/elements/canvasElements/CVCompElement.js +57 -0
  143. package/player/js/elements/canvasElements/CVContextData.js +239 -0
  144. package/player/js/elements/canvasElements/CVEffects.js +57 -0
  145. package/player/js/elements/canvasElements/CVImageElement.js +58 -0
  146. package/player/js/elements/canvasElements/CVMaskElement.js +72 -0
  147. package/player/js/elements/canvasElements/CVShapeElement.js +521 -0
  148. package/player/js/elements/canvasElements/CVSolidElement.js +30 -0
  149. package/player/js/elements/canvasElements/CVTextElement.js +244 -0
  150. package/player/js/elements/canvasElements/effects/CVGaussianBlurEffect.js +29 -0
  151. package/player/js/elements/canvasElements/effects/CVTransformEffect.js +9 -0
  152. package/player/js/elements/helpers/FrameElement.js +54 -0
  153. package/player/js/elements/helpers/HierarchyElement.js +52 -0
  154. package/player/js/elements/helpers/RenderableDOMElement.js +72 -0
  155. package/player/js/elements/helpers/RenderableElement.js +87 -0
  156. package/player/js/elements/helpers/TransformElement.js +140 -0
  157. package/player/js/elements/helpers/shapes/CVShapeData.js +33 -0
  158. package/player/js/elements/helpers/shapes/ProcessedElement.js +6 -0
  159. package/player/js/elements/helpers/shapes/SVGElementsRenderer.js +239 -0
  160. package/player/js/elements/helpers/shapes/SVGFillStyleData.js +18 -0
  161. package/player/js/elements/helpers/shapes/SVGGradientFillStyleData.js +100 -0
  162. package/player/js/elements/helpers/shapes/SVGGradientStrokeStyleData.js +20 -0
  163. package/player/js/elements/helpers/shapes/SVGNoStyleData.js +15 -0
  164. package/player/js/elements/helpers/shapes/SVGShapeData.js +28 -0
  165. package/player/js/elements/helpers/shapes/SVGStrokeStyleData.js +21 -0
  166. package/player/js/elements/helpers/shapes/SVGStyleData.js +19 -0
  167. package/player/js/elements/helpers/shapes/SVGTransformData.js +11 -0
  168. package/player/js/elements/helpers/shapes/ShapeElement.js +5 -0
  169. package/player/js/elements/helpers/shapes/ShapeGroupData.js +9 -0
  170. package/player/js/elements/helpers/shapes/ShapeTransformManager.js +61 -0
  171. package/player/js/elements/htmlElements/HBaseElement.js +88 -0
  172. package/player/js/elements/htmlElements/HCameraElement.js +170 -0
  173. package/player/js/elements/htmlElements/HCompElement.js +61 -0
  174. package/player/js/elements/htmlElements/HEffects.js +3 -0
  175. package/player/js/elements/htmlElements/HImageElement.js +42 -0
  176. package/player/js/elements/htmlElements/HShapeElement.js +261 -0
  177. package/player/js/elements/htmlElements/HSolidElement.js +36 -0
  178. package/player/js/elements/htmlElements/HTextElement.js +290 -0
  179. package/player/js/elements/svgElements/SVGBaseElement.js +181 -0
  180. package/player/js/elements/svgElements/SVGCompElement.js +28 -0
  181. package/player/js/elements/svgElements/SVGEffects.js +70 -0
  182. package/player/js/elements/svgElements/SVGEffectsPlaceholder.js +3 -0
  183. package/player/js/elements/svgElements/SVGShapeElement.js +366 -0
  184. package/player/js/elements/svgElements/SVGTextElement.js +322 -0
  185. package/player/js/elements/svgElements/effects/SVGComposableEffect.js +22 -0
  186. package/player/js/elements/svgElements/effects/SVGDropShadowEffect.js +83 -0
  187. package/player/js/elements/svgElements/effects/SVGFillFilter.js +22 -0
  188. package/player/js/elements/svgElements/effects/SVGGaussianBlurEffect.js +44 -0
  189. package/player/js/elements/svgElements/effects/SVGMatte3Effect.js +101 -0
  190. package/player/js/elements/svgElements/effects/SVGProLevelsFilter.js +108 -0
  191. package/player/js/elements/svgElements/effects/SVGStrokeEffect.js +119 -0
  192. package/player/js/elements/svgElements/effects/SVGTintEffect.js +47 -0
  193. package/player/js/elements/svgElements/effects/SVGTransformEffect.js +10 -0
  194. package/player/js/elements/svgElements/effects/SVGTritoneFilter.js +43 -0
  195. package/player/js/main.js +21 -0
  196. package/player/js/mask.js +239 -0
  197. package/player/js/module.js +153 -0
  198. package/player/js/modules/canvas.js +22 -0
  199. package/player/js/modules/canvas_light.js +25 -0
  200. package/player/js/modules/full.js +70 -0
  201. package/player/js/modules/full_worker.js +0 -0
  202. package/player/js/modules/html.js +37 -0
  203. package/player/js/modules/html_light.js +25 -0
  204. package/player/js/modules/main.js +162 -0
  205. package/player/js/modules/svg.js +37 -0
  206. package/player/js/modules/svg_light.js +25 -0
  207. package/player/js/renderers/BaseRenderer.js +187 -0
  208. package/player/js/renderers/CanvasRenderer.js +67 -0
  209. package/player/js/renderers/CanvasRendererBase.js +318 -0
  210. package/player/js/renderers/CanvasRendererWorkerOverride.js +54 -0
  211. package/player/js/renderers/HybridRenderer.js +47 -0
  212. package/player/js/renderers/HybridRendererBase.js +344 -0
  213. package/player/js/renderers/SVGRenderer.js +82 -0
  214. package/player/js/renderers/SVGRendererBase.js +255 -0
  215. package/player/js/renderers/renderersManager.js +29 -0
  216. package/player/js/utils/BaseEvent.js +42 -0
  217. package/player/js/utils/DataManager.js +676 -0
  218. package/player/js/utils/DataManagerWorkerOverrides.js +13 -0
  219. package/player/js/utils/FontManager.js +443 -0
  220. package/player/js/utils/FontManagerWorkerOverride.js +16 -0
  221. package/player/js/utils/PolynomialBezier.js +253 -0
  222. package/player/js/utils/PropertyFactory.js +489 -0
  223. package/player/js/utils/SlotManager.js +17 -0
  224. package/player/js/utils/TransformProperty.js +251 -0
  225. package/player/js/utils/animationFramePolyFill.js +25 -0
  226. package/player/js/utils/asset_loader.js +53 -0
  227. package/player/js/utils/asset_loader_worker_override.js +3 -0
  228. package/player/js/utils/audio/AudioController.js +85 -0
  229. package/player/js/utils/audio/AudioElement.js +6 -0
  230. package/player/js/utils/bez.js +251 -0
  231. package/player/js/utils/common.js +280 -0
  232. package/player/js/utils/expressions/CompInterface.js +28 -0
  233. package/player/js/utils/expressions/EffectInterface.js +111 -0
  234. package/player/js/utils/expressions/ExpressionManager.js +752 -0
  235. package/player/js/utils/expressions/ExpressionPropertyDecorator.js +463 -0
  236. package/player/js/utils/expressions/ExpressionTextPropertyDecorator.js +40 -0
  237. package/player/js/utils/expressions/ExpressionValue.js +61 -0
  238. package/player/js/utils/expressions/ExpressionValueFactory.js +102 -0
  239. package/player/js/utils/expressions/Expressions.js +48 -0
  240. package/player/js/utils/expressions/FootageInterface.js +60 -0
  241. package/player/js/utils/expressions/InterfacesProvider.js +21 -0
  242. package/player/js/utils/expressions/LayerInterface.js +179 -0
  243. package/player/js/utils/expressions/MaskInterface.js +50 -0
  244. package/player/js/utils/expressions/ProjectInterface.js +31 -0
  245. package/player/js/utils/expressions/PropertyGroupFactory.js +13 -0
  246. package/player/js/utils/expressions/PropertyInterface.js +19 -0
  247. package/player/js/utils/expressions/ShapeInterface.js +543 -0
  248. package/player/js/utils/expressions/TextInterface.js +35 -0
  249. package/player/js/utils/expressions/TextSelectorPropertyDecorator.js +44 -0
  250. package/player/js/utils/expressions/TransformInterface.js +126 -0
  251. package/player/js/utils/expressions/expressionHelpers.js +86 -0
  252. package/player/js/utils/expressions/shapes/ShapePathInterface.js +47 -0
  253. package/player/js/utils/featureSupport.js +16 -0
  254. package/player/js/utils/filters.js +32 -0
  255. package/player/js/utils/functionExtensions.js +27 -0
  256. package/player/js/utils/getFontProperties.js +42 -0
  257. package/player/js/utils/helpers/arrays.js +43 -0
  258. package/player/js/utils/helpers/assetManager.js +96 -0
  259. package/player/js/utils/helpers/blendModes.js +26 -0
  260. package/player/js/utils/helpers/bufferManager.js +61 -0
  261. package/player/js/utils/helpers/dynamicProperties.js +29 -0
  262. package/player/js/utils/helpers/effectTypes.js +3 -0
  263. package/player/js/utils/helpers/html_elements.js +6 -0
  264. package/player/js/utils/helpers/propTypes.js +3 -0
  265. package/player/js/utils/helpers/shapeEnums.js +16 -0
  266. package/player/js/utils/helpers/svg_elements.js +8 -0
  267. package/player/js/utils/imagePreloader.js +213 -0
  268. package/player/js/utils/imagePreloaderWorkerOverride.js +3 -0
  269. package/player/js/utils/markers/markerParser.js +47 -0
  270. package/player/js/utils/pooling/bezier_length_pool.js +20 -0
  271. package/player/js/utils/pooling/point_pool.js +13 -0
  272. package/player/js/utils/pooling/pool_factory.js +44 -0
  273. package/player/js/utils/pooling/pooling.js +15 -0
  274. package/player/js/utils/pooling/segments_length_pool.js +24 -0
  275. package/player/js/utils/pooling/shapeCollection_pool.js +48 -0
  276. package/player/js/utils/pooling/shape_pool.js +44 -0
  277. package/player/js/utils/shapes/DashProperty.js +63 -0
  278. package/player/js/utils/shapes/GradientProperty.js +93 -0
  279. package/player/js/utils/shapes/MouseModifier.js +222 -0
  280. package/player/js/utils/shapes/OffsetPathModifier.js +306 -0
  281. package/player/js/utils/shapes/PuckerAndBloatModifier.js +80 -0
  282. package/player/js/utils/shapes/RepeaterModifier.js +232 -0
  283. package/player/js/utils/shapes/RoundCornersModifier.js +122 -0
  284. package/player/js/utils/shapes/ShapeCollection.js +29 -0
  285. package/player/js/utils/shapes/ShapeModifiers.js +71 -0
  286. package/player/js/utils/shapes/ShapePath.js +100 -0
  287. package/player/js/utils/shapes/ShapeProperty.js +546 -0
  288. package/player/js/utils/shapes/TrimModifier.js +359 -0
  289. package/player/js/utils/shapes/ZigZagModifier.js +174 -0
  290. package/player/js/utils/shapes/shapePathBuilder.js +20 -0
  291. package/player/js/utils/text/LetterProps.js +60 -0
  292. package/player/js/utils/text/TextAnimatorDataProperty.js +34 -0
  293. package/player/js/utils/text/TextAnimatorProperty.js +610 -0
  294. package/player/js/utils/text/TextProperty.js +461 -0
  295. package/player/js/utils/text/TextSelectorProperty.js +179 -0
  296. package/player/js/worker_wrapper.js +1029 -0
  297. package/rollup.config.js +215 -0
  298. package/tasks/build.js +773 -0
  299. package/tasks/build_worker.js +164 -0
  300. package/tasks/watch.js +34 -0
@@ -0,0 +1,31 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-04/schema#",
3
+ "type": "object",
4
+ "properties": {
5
+ "h": {
6
+ "title": "Height",
7
+ "description": "Image Height",
8
+ "type": "number"
9
+ },
10
+ "w": {
11
+ "title": "Width",
12
+ "description": "Image Width",
13
+ "type": "number"
14
+ },
15
+ "id": {
16
+ "title": "ID",
17
+ "description": "Image ID",
18
+ "type": "string"
19
+ },
20
+ "p": {
21
+ "title": "Image name",
22
+ "description": "Image name",
23
+ "type": "string"
24
+ },
25
+ "u": {
26
+ "title": "Image path",
27
+ "description": "Image path",
28
+ "type": "string"
29
+ }
30
+ }
31
+ }
@@ -0,0 +1,39 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-04/schema#",
3
+ "type": "object",
4
+ "properties": {
5
+ "id": {
6
+ "title": "ID",
7
+ "description": "Precomp ID",
8
+ "type": "string"
9
+ },
10
+ "layers": {
11
+ "title": "Layers",
12
+ "description": "List of Precomp Layers",
13
+ "items": {
14
+ "oneOf": [
15
+ {
16
+ "$ref": "#/layers/shape"
17
+ },
18
+ {
19
+ "$ref": "#/layers/solid"
20
+ },
21
+ {
22
+ "$ref": "#/layers/preComp"
23
+ },
24
+ {
25
+ "$ref": "#/layers/image"
26
+ },
27
+ {
28
+ "$ref": "#/layers/null"
29
+ },
30
+ {
31
+ "$ref": "#/layers/text"
32
+ }
33
+ ],
34
+ "type": "object"
35
+ },
36
+ "type": "array"
37
+ }
38
+ }
39
+ }
package/index.d.ts ADDED
@@ -0,0 +1,197 @@
1
+ export type AnimationDirection = 1 | -1;
2
+ export type AnimationSegment = [number, number];
3
+ export type AnimationEventName = 'drawnFrame' | 'enterFrame' | 'loopComplete' | 'complete' | 'segmentStart' | 'destroy' | 'config_ready' | 'data_ready' | 'DOMLoaded' | 'error' | 'data_failed' | 'loaded_images';
4
+ export type AnimationEventCallback<T = any> = (args: T) => void;
5
+
6
+ /** Specifies the data for each event type. */
7
+ export interface AnimationEvents {
8
+ DOMLoaded: undefined;
9
+ complete: BMCompleteEvent;
10
+ config_ready: undefined;
11
+ data_failed: undefined;
12
+ data_ready: undefined;
13
+ destroy: BMDestroyEvent;
14
+ drawnFrame: BMEnterFrameEvent;
15
+ enterFrame: BMEnterFrameEvent;
16
+ error: undefined;
17
+ loaded_images: undefined;
18
+ loopComplete: BMCompleteLoopEvent;
19
+ segmentStart: BMSegmentStartEvent;
20
+ }
21
+
22
+ export interface BMCompleteEvent {
23
+ direction: number;
24
+ type: "complete";
25
+ }
26
+
27
+ export interface BMCompleteLoopEvent {
28
+ currentLoop: number;
29
+ direction: number;
30
+ totalLoops: number;
31
+ type: "loopComplete";
32
+ }
33
+
34
+ export interface BMDestroyEvent {
35
+ type: "destroy";
36
+ }
37
+
38
+ export interface BMEnterFrameEvent {
39
+ /** The current time in frames. */
40
+ currentTime: number;
41
+ direction: number;
42
+ /** The total number of frames. */
43
+ totalTime: number;
44
+ type: "enterFrame";
45
+ }
46
+
47
+ export interface BMSegmentStartEvent {
48
+ firstFrame: number;
49
+ totalFrames: number;
50
+ type: "segmentStart";
51
+ }
52
+
53
+ export type AnimationItem = {
54
+ name: string;
55
+ isLoaded: boolean;
56
+ currentFrame: number;
57
+ currentRawFrame: number;
58
+ firstFrame: number;
59
+ totalFrames: number;
60
+ frameRate: number;
61
+ frameMult: number;
62
+ playSpeed: number;
63
+ playDirection: number;
64
+ playCount: number;
65
+ isPaused: boolean;
66
+ autoplay: boolean;
67
+ loop: boolean | number;
68
+ renderer: any;
69
+ animationID: string;
70
+ assetsPath: string;
71
+ timeCompleted: number;
72
+ segmentPos: number;
73
+ isSubframeEnabled: boolean;
74
+ segments: AnimationSegment | AnimationSegment[];
75
+ play(name?: string): void;
76
+ stop(name?: string): void;
77
+ togglePause(name?: string): void;
78
+ destroy(name?: string): void;
79
+ pause(name?: string): void;
80
+ goToAndStop(value: number | string, isFrame?: boolean, name?: string): void;
81
+ goToAndPlay(value: number | string, isFrame?: boolean, name?: string): void;
82
+ includeLayers(data: any): void;
83
+ setSegment(init: number, end: number): void;
84
+ resetSegments(forceFlag: boolean): void;
85
+ hide(): void;
86
+ show(): void;
87
+ resize(width?: number, height?: number): void;
88
+ setSpeed(speed: number): void;
89
+ setDirection(direction: AnimationDirection): void;
90
+ setLoop(isLooping: boolean): void;
91
+ playSegments(segments: AnimationSegment | AnimationSegment[], forceFlag?: boolean): void;
92
+ setSubframe(useSubFrames: boolean): void;
93
+ getDuration(inFrames?: boolean): number;
94
+ triggerEvent<T extends AnimationEventName>(name: T, args: AnimationEvents[T]): void;
95
+ addEventListener<T extends AnimationEventName>(name: T, callback: AnimationEventCallback<AnimationEvents[T]>): () => void;
96
+ removeEventListener<T extends AnimationEventName>(name: T, callback?: AnimationEventCallback<AnimationEvents[T]>): void;
97
+ }
98
+
99
+ export type BaseRendererConfig = {
100
+ imagePreserveAspectRatio?: string;
101
+ className?: string;
102
+ };
103
+
104
+ export type SVGRendererConfig = BaseRendererConfig & {
105
+ title?: string;
106
+ description?: string;
107
+ preserveAspectRatio?: string;
108
+ progressiveLoad?: boolean;
109
+ hideOnTransparent?: boolean;
110
+ viewBoxOnly?: boolean;
111
+ viewBoxSize?: string;
112
+ focusable?: boolean;
113
+ filterSize?: FilterSizeConfig;
114
+ };
115
+
116
+ export type CanvasRendererConfig = BaseRendererConfig & {
117
+ clearCanvas?: boolean;
118
+ context?: CanvasRenderingContext2D;
119
+ progressiveLoad?: boolean;
120
+ preserveAspectRatio?: string;
121
+ dpr?: number;
122
+ };
123
+
124
+ export type HTMLRendererConfig = BaseRendererConfig & {
125
+ hideOnTransparent?: boolean;
126
+ };
127
+
128
+ export type RendererType = 'svg' | 'canvas' | 'html';
129
+
130
+ export type AnimationConfig<T extends RendererType = 'svg'> = {
131
+ container: Element;
132
+ renderer?: T;
133
+ loop?: boolean | number;
134
+ autoplay?: boolean;
135
+ initialSegment?: AnimationSegment;
136
+ name?: string;
137
+ assetsPath?: string;
138
+ rendererSettings?: {
139
+ svg: SVGRendererConfig;
140
+ canvas: CanvasRendererConfig;
141
+ html: HTMLRendererConfig;
142
+ }[T]
143
+ audioFactory?(assetPath: string): {
144
+ play(): void
145
+ seek(): void
146
+ playing(): void
147
+ rate(): void
148
+ setVolume(): void
149
+ }
150
+ }
151
+
152
+ export type TextDocumentData = {
153
+ t?: string;
154
+ s?: number;
155
+ f?: string;
156
+ ca?: number;
157
+ j?: number;
158
+ tr?: number;
159
+ lh?: number;
160
+ ls?: number;
161
+ fc?: [number, number, number];
162
+ }
163
+
164
+ export type AnimationConfigWithPath<T extends RendererType = 'svg'> = AnimationConfig<T> & {
165
+ path?: string;
166
+ }
167
+
168
+ export type AnimationConfigWithData<T extends RendererType = 'svg'> = AnimationConfig<T> & {
169
+ animationData?: any;
170
+ }
171
+
172
+ export type FilterSizeConfig = {
173
+ width: string;
174
+ height: string;
175
+ x: string;
176
+ y: string;
177
+ };
178
+
179
+ export type LottiePlayer = {
180
+ play(name?: string): void;
181
+ pause(name?: string): void;
182
+ stop(name?: string): void;
183
+ setSpeed(speed: number, name?: string): void;
184
+ setDirection(direction: AnimationDirection, name?: string): void;
185
+ searchAnimations(animationData?: any, standalone?: boolean, renderer?: string): void;
186
+ loadAnimation<T extends RendererType = 'svg'>(params: AnimationConfigWithPath<T> | AnimationConfigWithData<T>): AnimationItem;
187
+ destroy(name?: string): void;
188
+ registerAnimation(element: Element, animationData?: any): void;
189
+ setQuality(quality: string | number): void;
190
+ setLocationHref(href: string): void;
191
+ setIDPrefix(prefix: string): void;
192
+ updateDocumentData(path: (string|number)[], documentData: TextDocumentData, index: number): void;
193
+ };
194
+
195
+ declare const Lottie: LottiePlayer;
196
+
197
+ export default Lottie;
package/package.json ADDED
@@ -0,0 +1,54 @@
1
+ {
2
+ "name": "@lumen5/lottie-web",
3
+ "version": "5.14.0",
4
+ "description": "After Effects plugin for exporting animations to SVG + JavaScript or canvas + JavaScript",
5
+ "main": "./build/player/lottie.js",
6
+ "repository": {
7
+ "type": "git",
8
+ "url": "https://github.com/Lumen5/lottie-web.git"
9
+ },
10
+ "publishConfig": {
11
+ "access": "public"
12
+ },
13
+ "sideEffects": false,
14
+ "scripts": {
15
+ "build": "npx eslint ./player/js/**/* && rollup -c && node tasks/build_worker",
16
+ "build_test": "node tasks/build.js",
17
+ "lint": "npx eslint ./player/js/**/*",
18
+ "lint:fix": "npx eslint ./player/js/**/* --fix",
19
+ "test:create": "node test/index.js",
20
+ "test:compare": "node test/index.js -s compare",
21
+ "serve": "npx serve -p 3000",
22
+ "dev": "npm run build && npx serve -p 3000"
23
+ },
24
+ "keywords": [
25
+ "animation",
26
+ "canvas",
27
+ "svg",
28
+ "after effects",
29
+ "plugin",
30
+ "export"
31
+ ],
32
+ "devDependencies": {
33
+ "@babel/core": "^7.16.0",
34
+ "@babel/plugin-transform-runtime": "^7.17.0",
35
+ "@babel/preset-env": "^7.16.4",
36
+ "@rollup/plugin-babel": "^5.3.0",
37
+ "@rollup/plugin-node-resolve": "^13.0.6",
38
+ "cheerio": "^1.0.0-rc.2",
39
+ "command-line-args": "^5.2.1",
40
+ "eslint": "^7.16.0",
41
+ "eslint-config-airbnb-base": "^14.2.1",
42
+ "eslint-plugin-import": "^2.22.1",
43
+ "express": "^4.18.2",
44
+ "pixelmatch": "^5.3.0",
45
+ "pngjs": "^7.0.0",
46
+ "puppeteer": "^24.40.0",
47
+ "rollup": "^2.61.0",
48
+ "rollup-plugin-terser": "^7.0.2",
49
+ "uglify-js": "^3.4.9",
50
+ "watch": "^1.0.2"
51
+ },
52
+ "types": "./index.d.ts",
53
+ "license": "MIT"
54
+ }
@@ -0,0 +1,115 @@
1
+ <!DOCTYPE html>
2
+ <html xmlns="http://www.w3.org/1999/xhtml">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <style>
6
+ body, html{
7
+ background-color:#ccc;
8
+ margin: 0px;
9
+ height: 100%;
10
+ overflow-x: hidden;
11
+ overflow-y: auto;
12
+ }
13
+
14
+ #pusher{
15
+ background-color:#ccc;
16
+ width:100%;
17
+ height:0%;
18
+ display:block;
19
+ overflow: hidden;
20
+ transform: translate3d(0,0,0);
21
+ /*display:none;*/
22
+ }
23
+
24
+ #lottie{
25
+ background-color:#ccc;
26
+ width:100%;
27
+ height:100%;
28
+ display:block;
29
+ overflow: hidden;
30
+ transform: translate3d(0,0,0);
31
+ /*display:none;*/
32
+ }
33
+
34
+ </style>
35
+ <!-- build:js lottie.js -->
36
+
37
+ <!-- end Expressions -->
38
+ <!-- endbuild -->
39
+ <!-- <script src="js/module.js" type="module"></script> -->
40
+ <!-- <script src="lottie.js"></script> -->
41
+ <!-- <script src="bodymovin_light.js"></script> -->
42
+
43
+
44
+
45
+ </head>
46
+ <body>
47
+ <div id="pusher"></div>
48
+ <div id="lottie"></div>
49
+
50
+ <script>
51
+ var anim;
52
+ import('./js/modules/full.js').then(({default: lottie }) => {
53
+ var elem = document.getElementById('lottie');
54
+ var animData = {
55
+ container: elem,
56
+ renderer: 'svg',
57
+ loop: 3,
58
+ autoplay: true,
59
+ rendererSettings: {
60
+ progressiveLoad:false,
61
+ preserveAspectRatio: 'xMidYMid meet',
62
+ imagePreserveAspectRatio: 'xMidYMid meet',
63
+ title: 'TEST TITLE',
64
+ description: 'TEST DESCRIPTION',
65
+ filterSize: {
66
+ width: '500%',
67
+ height: '500%',
68
+ x: '-200%',
69
+ y: '-200%',
70
+ }
71
+ },
72
+ path: 'exports/render/data.json',
73
+ audioFactory: createAudio,
74
+ };
75
+ // lottie.setQuality('low');
76
+ // anim.setSpeed(0.5)
77
+ // lottie.useWebWorker(true);
78
+ window.lottie = lottie;
79
+ setTimeout(() => {
80
+
81
+ anim = lottie.loadAnimation(animData);
82
+ anim.setSubframe(false);
83
+ anim.onError = function(errorType, nativeError, errorProps) {
84
+ console.log(errorType)
85
+ }
86
+
87
+ anim.addEventListener('error', function(error) {
88
+ console.log(error)
89
+ })
90
+
91
+ anim.addEventListener('error', function(error) {
92
+ console.log(error)
93
+ })
94
+
95
+ anim.addEventListener('DOMLoaded', function() {
96
+ // setTimeout(()=>{
97
+ // console.log('UPDATEING TEXT');
98
+ // anim.updateDocumentData(['a_text','adwqd'], {t: 'eeee'});
99
+ // }, 100)
100
+ })
101
+ }, 1)
102
+ });
103
+
104
+ // setTimeout(()=>anim.destroy(), 1000);
105
+
106
+ function createAudio(assetPath) {
107
+ return new Howl({
108
+ src: [assetPath]
109
+ })
110
+ }
111
+
112
+ </script>
113
+
114
+ </body>
115
+ </html>
@@ -0,0 +1,158 @@
1
+ /* eslint-disable */
2
+ const BezierFactory = (function () {
3
+ /**
4
+ * BezierEasing - use bezier curve for transition easing function
5
+ * by Gaëtan Renaudeau 2014 - 2015 – MIT License
6
+ *
7
+ * Credits: is based on Firefox's nsSMILKeySpline.cpp
8
+ * Usage:
9
+ * var spline = BezierEasing([ 0.25, 0.1, 0.25, 1.0 ])
10
+ * spline.get(x) => returns the easing value | x must be in [0, 1] range
11
+ *
12
+ */
13
+
14
+ var ob = {};
15
+ ob.getBezierEasing = getBezierEasing;
16
+ var beziers = {};
17
+
18
+ function getBezierEasing(a, b, c, d, nm) {
19
+ var str = nm || ('bez_' + a + '_' + b + '_' + c + '_' + d).replace(/\./g, 'p');
20
+ if (beziers[str]) {
21
+ return beziers[str];
22
+ }
23
+ var bezEasing = new BezierEasing([a, b, c, d]);
24
+ beziers[str] = bezEasing;
25
+ return bezEasing;
26
+ }
27
+
28
+ // These values are established by empiricism with tests (tradeoff: performance VS precision)
29
+ var NEWTON_ITERATIONS = 4;
30
+ var NEWTON_MIN_SLOPE = 0.001;
31
+ var SUBDIVISION_PRECISION = 0.0000001;
32
+ var SUBDIVISION_MAX_ITERATIONS = 10;
33
+
34
+ var kSplineTableSize = 11;
35
+ var kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);
36
+
37
+ var float32ArraySupported = typeof Float32Array === 'function';
38
+
39
+ function A(aA1, aA2) { return 1.0 - 3.0 * aA2 + 3.0 * aA1; }
40
+ function B(aA1, aA2) { return 3.0 * aA2 - 6.0 * aA1; }
41
+ function C(aA1) { return 3.0 * aA1; }
42
+
43
+ // Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.
44
+ function calcBezier(aT, aA1, aA2) {
45
+ return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT;
46
+ }
47
+
48
+ // Returns dx/dt given t, x1, and x2, or dy/dt given t, y1, and y2.
49
+ function getSlope(aT, aA1, aA2) {
50
+ return 3.0 * A(aA1, aA2) * aT * aT + 2.0 * B(aA1, aA2) * aT + C(aA1);
51
+ }
52
+
53
+ function binarySubdivide(aX, aA, aB, mX1, mX2) {
54
+ var currentX,
55
+ currentT,
56
+ i = 0;
57
+ do {
58
+ currentT = aA + (aB - aA) / 2.0;
59
+ currentX = calcBezier(currentT, mX1, mX2) - aX;
60
+ if (currentX > 0.0) {
61
+ aB = currentT;
62
+ } else {
63
+ aA = currentT;
64
+ }
65
+ } while (Math.abs(currentX) > SUBDIVISION_PRECISION && ++i < SUBDIVISION_MAX_ITERATIONS);
66
+ return currentT;
67
+ }
68
+
69
+ function newtonRaphsonIterate(aX, aGuessT, mX1, mX2) {
70
+ for (var i = 0; i < NEWTON_ITERATIONS; ++i) {
71
+ var currentSlope = getSlope(aGuessT, mX1, mX2);
72
+ if (currentSlope === 0.0) return aGuessT;
73
+ var currentX = calcBezier(aGuessT, mX1, mX2) - aX;
74
+ aGuessT -= currentX / currentSlope;
75
+ }
76
+ return aGuessT;
77
+ }
78
+
79
+ /**
80
+ * points is an array of [ mX1, mY1, mX2, mY2 ]
81
+ */
82
+ function BezierEasing(points) {
83
+ this._p = points;
84
+ this._mSampleValues = float32ArraySupported ? new Float32Array(kSplineTableSize) : new Array(kSplineTableSize);
85
+ this._precomputed = false;
86
+
87
+ this.get = this.get.bind(this);
88
+ }
89
+
90
+ BezierEasing.prototype = {
91
+
92
+ get: function (x) {
93
+ var mX1 = this._p[0],
94
+ mY1 = this._p[1],
95
+ mX2 = this._p[2],
96
+ mY2 = this._p[3];
97
+ if (!this._precomputed) this._precompute();
98
+ if (mX1 === mY1 && mX2 === mY2) return x; // linear
99
+ // Because JavaScript number are imprecise, we should guarantee the extremes are right.
100
+ if (x === 0) return 0;
101
+ if (x === 1) return 1;
102
+ return calcBezier(this._getTForX(x), mY1, mY2);
103
+ },
104
+
105
+ // Private part
106
+
107
+ _precompute: function () {
108
+ var mX1 = this._p[0],
109
+ mY1 = this._p[1],
110
+ mX2 = this._p[2],
111
+ mY2 = this._p[3];
112
+ this._precomputed = true;
113
+ if (mX1 !== mY1 || mX2 !== mY2) { this._calcSampleValues(); }
114
+ },
115
+
116
+ _calcSampleValues: function () {
117
+ var mX1 = this._p[0],
118
+ mX2 = this._p[2];
119
+ for (var i = 0; i < kSplineTableSize; ++i) {
120
+ this._mSampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);
121
+ }
122
+ },
123
+
124
+ /**
125
+ * getTForX chose the fastest heuristic to determine the percentage value precisely from a given X projection.
126
+ */
127
+ _getTForX: function (aX) {
128
+ var mX1 = this._p[0],
129
+ mX2 = this._p[2],
130
+ mSampleValues = this._mSampleValues;
131
+
132
+ var intervalStart = 0.0;
133
+ var currentSample = 1;
134
+ var lastSample = kSplineTableSize - 1;
135
+
136
+ for (; currentSample !== lastSample && mSampleValues[currentSample] <= aX; ++currentSample) {
137
+ intervalStart += kSampleStepSize;
138
+ }
139
+ --currentSample;
140
+
141
+ // Interpolate to provide an initial guess for t
142
+ var dist = (aX - mSampleValues[currentSample]) / (mSampleValues[currentSample + 1] - mSampleValues[currentSample]);
143
+ var guessForT = intervalStart + dist * kSampleStepSize;
144
+
145
+ var initialSlope = getSlope(guessForT, mX1, mX2);
146
+ if (initialSlope >= NEWTON_MIN_SLOPE) {
147
+ return newtonRaphsonIterate(aX, guessForT, mX1, mX2);
148
+ } if (initialSlope === 0.0) {
149
+ return guessForT;
150
+ }
151
+ return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2);
152
+ },
153
+ };
154
+
155
+ return ob;
156
+ }());
157
+
158
+ export default BezierFactory;