├── .gitattributes ├── src ├── Blazor.Lottie.Player │ ├── _Imports.razor │ ├── wwwroot │ │ ├── Nuget.png │ │ ├── loadLottieWeb.js │ │ ├── lottiePlayerModule.js │ │ └── loading.json │ ├── Component │ │ ├── LottiePlayer.razor │ │ ├── LottiePlaybackOptions.cs │ │ ├── LottiePlayerModule.cs │ │ └── LottiePlayer.razor.cs │ ├── Enums │ │ ├── LottieAnimationDirection.cs │ │ ├── LottieAnimationType.cs │ │ └── LottieAnimationQuality.cs │ ├── EventArgs │ │ ├── LottiePlayerLoadedEventArgs.cs │ │ └── LottiePlayerEventFrameArgs.cs │ ├── Extensions │ │ ├── Identifier.cs │ │ └── EnumExtensions.cs │ ├── Blazor.Lottie.Player.csproj │ ├── Configuration │ │ └── LottieAnimationOptions.cs │ └── Player-API-Documentation.txt ├── Blazor.Lottie.Player.Docs.WASM │ ├── wwwroot │ │ ├── MudX_Transparent_Logo.ico │ │ ├── MudX_Transparent_Logo.png │ │ ├── index.html │ │ ├── css │ │ │ └── app.css │ │ └── lottie │ │ │ ├── BunBun.json │ │ │ └── newAnimation.json │ ├── Layout │ │ └── MainLayout.razor │ ├── App.razor │ ├── _Imports.razor │ ├── Program.cs │ ├── Blazor.Lottie.Player.Docs.WASM.csproj │ ├── Properties │ │ └── launchSettings.json │ └── Pages │ │ └── Home.razor ├── Readme.txt └── Blazor.Lottie.Player.sln ├── tests ├── README.md └── Blazor.Lottie.Player.UnitTests │ ├── BunitTest.cs │ ├── Blazor.Lottie.Player.UnitTests.csproj │ ├── LottieModuleTests.cs │ └── LottieTests.cs ├── docs └── README.md ├── LICENSE ├── README.md ├── .editorconfig └── .gitignore /.gitattributes: -------------------------------------------------------------------------------- 1 | # Force this repository to use Windows line endings 2 | * text=auto -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/_Imports.razor: -------------------------------------------------------------------------------- 1 | @using Microsoft.AspNetCore.Components.Web 2 | -------------------------------------------------------------------------------- /tests/README.md: -------------------------------------------------------------------------------- 1 | # Tests 2 | Unit, integration, acceptance, etc tests should go here. Preferred framework is xUnit. -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/wwwroot/Nuget.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/MudXtra/LottiePlayer/HEAD/src/Blazor.Lottie.Player/wwwroot/Nuget.png -------------------------------------------------------------------------------- /docs/README.md: -------------------------------------------------------------------------------- 1 | # Documentation 2 | Any documentation relevant to the project should be included here. General info can go in this README, but adding extra files is acceptable. 3 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/wwwroot/MudX_Transparent_Logo.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/MudXtra/LottiePlayer/HEAD/src/Blazor.Lottie.Player.Docs.WASM/wwwroot/MudX_Transparent_Logo.ico -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/wwwroot/MudX_Transparent_Logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/MudXtra/LottiePlayer/HEAD/src/Blazor.Lottie.Player.Docs.WASM/wwwroot/MudX_Transparent_Logo.png -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/Layout/MainLayout.razor: -------------------------------------------------------------------------------- 1 | @inherits LayoutComponentBase 2 | 3 | @using MudBlazor 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | @Body 12 | -------------------------------------------------------------------------------- /src/Readme.txt: -------------------------------------------------------------------------------- 1 | First Update the Version in csproj file. 2 | Set Mode to Release. 3 | Manually run right click, pack, then upload the .nupkg file to NuGet.org. 4 | Push changes to Github repository. 5 | When Nuget package is updated, update the MudX. 6 | Set Mode back to Debug. 7 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Component/LottiePlayer.razor: -------------------------------------------------------------------------------- 1 | @namespace Blazor.Lottie.Player 2 | @inherits ComponentBase 3 | 4 |
5 | @if (_failMessage != null) 6 | { 7 | @_failMessage 8 | } 9 |
10 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Enums/LottieAnimationDirection.cs: -------------------------------------------------------------------------------- 1 | namespace Blazor.Lottie.Player; 2 | /// 3 | /// Specifies the playback direction for a Lottie animation. 4 | /// 5 | public enum LottieAnimationDirection 6 | { 7 | /// 8 | /// Represents the forward direction an animation will play. 9 | /// 10 | Forward = 1, 11 | /// 12 | /// Represents the reverse direction an animation will play. 13 | /// 14 | Reverse = -1, 15 | } 16 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/App.razor: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Not found 8 | 9 |

Sorry, there's nothing at this address.

10 |
11 |
12 |
13 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/_Imports.razor: -------------------------------------------------------------------------------- 1 | @using System.Net.Http 2 | @using System.Net.Http.Json 3 | @using Microsoft.AspNetCore.Components.Forms 4 | @using Microsoft.AspNetCore.Components.Routing 5 | @using Microsoft.AspNetCore.Components.Web 6 | @using Microsoft.AspNetCore.Components.Web.Virtualization 7 | @using Microsoft.AspNetCore.Components.WebAssembly.Http 8 | @using Microsoft.JSInterop 9 | @using Blazor.Lottie.Player.Docs.WASM 10 | @using Blazor.Lottie.Player.Docs.WASM.Layout 11 | 12 | @using Blazor.Lottie.Player 13 | @using MudBlazor 14 | @using MudX 15 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/Program.cs: -------------------------------------------------------------------------------- 1 | using Blazor.Lottie.Player.Docs.WASM; 2 | using Microsoft.AspNetCore.Components.Web; 3 | using Microsoft.AspNetCore.Components.WebAssembly.Hosting; 4 | using MudBlazor.Services; 5 | 6 | var builder = WebAssemblyHostBuilder.CreateDefault(args); 7 | builder.RootComponents.Add("#app"); 8 | builder.RootComponents.Add("head::after"); 9 | 10 | builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri(builder.HostEnvironment.BaseAddress) }); 11 | 12 | builder.Services.AddMudServices(); 13 | 14 | await builder.Build().RunAsync(); 15 | -------------------------------------------------------------------------------- /tests/Blazor.Lottie.Player.UnitTests/BunitTest.cs: -------------------------------------------------------------------------------- 1 | using Bunit; 2 | 3 | namespace Blazor.Lottie.Player.UnitTests; 4 | public abstract class BunitTest 5 | { 6 | protected Bunit.TestContext Context { get; private set; } = null!; 7 | 8 | [SetUp] 9 | public virtual void Setup() 10 | { 11 | Context = new Bunit.TestContext(); 12 | //Context.Services.; // This is where you add services if needed 13 | Context.JSInterop.Mode = JSRuntimeMode.Loose; // Use Loose mode for JS Interop 14 | } 15 | 16 | [TearDown] 17 | public virtual void TearDown() 18 | { 19 | Context.Dispose(); 20 | Context = null!; 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/EventArgs/LottiePlayerLoadedEventArgs.cs: -------------------------------------------------------------------------------- 1 | namespace Blazor.Lottie.Player; 2 | /// 3 | /// Event arguments for the Lottie player loaded event. 4 | /// 5 | public record LottiePlayerLoadedEventArgs 6 | { 7 | /// 8 | /// Gets the ID of the Lottie player element. 9 | /// 10 | public string ElementId { get; init; } = default!; 11 | 12 | /// 13 | /// Gets the current frame of the animation as a zero-based index. 14 | /// 15 | public double CurrentFrame { get; init; } 16 | 17 | /// 18 | /// Gets the total number of frames processed. 19 | /// 20 | public double TotalFrames { get; init; } 21 | 22 | } 23 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Extensions/Identifier.cs: -------------------------------------------------------------------------------- 1 | namespace Blazor.Lottie.Player.Extensions; 2 | internal class Identifier 3 | { 4 | private const string _chars = "abcdefghijklmnopqrstuvwxyz0123456789"; 5 | private const int _charsLength = 35; 6 | private const int _randomStringLength = 8; 7 | 8 | public static string Create(ReadOnlySpan prefix) 9 | { 10 | Span identifierSpan = stackalloc char[prefix.Length + _randomStringLength]; 11 | prefix.CopyTo(identifierSpan); 12 | for (var i = 0; i < _randomStringLength; i++) 13 | { 14 | var index = Random.Shared.Next(_charsLength); 15 | identifierSpan[prefix.Length + i] = _chars[index]; 16 | } 17 | return identifierSpan.ToString(); 18 | } 19 | 20 | public static string Create() => Create("mudxtra-"); 21 | } 22 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/Blazor.Lottie.Player.Docs.WASM.csproj: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | net9.0 5 | enable 6 | enable 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/EventArgs/LottiePlayerEventFrameArgs.cs: -------------------------------------------------------------------------------- 1 | namespace Blazor.Lottie.Player; 2 | /// 3 | /// Event arguments for the Lottie player loaded event. 4 | /// 5 | public record LottiePlayerEventFrameArgs 6 | { 7 | /// 8 | /// Gets the ID of the event. 9 | /// 10 | public string Type { get; init; } = "enterFrame"; 11 | 12 | /// 13 | /// Gets the current frame of the animation as a zero-based index. 14 | /// 15 | public double CurrentTime { get; init; } 16 | 17 | /// 18 | /// Gets the total number of frames to be processed. 19 | /// 20 | public double TotalTime { get; init; } 21 | 22 | /// 23 | /// The current direction of the Lottie animation playback. 24 | /// 25 | public LottieAnimationDirection Direction { get; init; } = LottieAnimationDirection.Forward; 26 | 27 | } 28 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/Properties/launchSettings.json: -------------------------------------------------------------------------------- 1 | { 2 | "$schema": "https://json.schemastore.org/launchsettings.json", 3 | "profiles": { 4 | "http": { 5 | "commandName": "Project", 6 | "dotnetRunMessages": true, 7 | "launchBrowser": true, 8 | "inspectUri": "{wsProtocol}://{url.hostname}:{url.port}/_framework/debug/ws-proxy?browser={browserInspectUri}", 9 | "applicationUrl": "http://localhost:5266", 10 | "environmentVariables": { 11 | "ASPNETCORE_ENVIRONMENT": "Development" 12 | } 13 | }, 14 | "https": { 15 | "commandName": "Project", 16 | "dotnetRunMessages": true, 17 | "launchBrowser": true, 18 | "inspectUri": "{wsProtocol}://{url.hostname}:{url.port}/_framework/debug/ws-proxy?browser={browserInspectUri}", 19 | "applicationUrl": "https://localhost:7190;http://localhost:5266", 20 | "environmentVariables": { 21 | "ASPNETCORE_ENVIRONMENT": "Development" 22 | } 23 | } 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2024 Bell County, TX 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Enums/LottieAnimationType.cs: -------------------------------------------------------------------------------- 1 | using System.ComponentModel; 2 | 3 | namespace Blazor.Lottie.Player 4 | { 5 | /// 6 | /// Specifies the type of Lottie animation to render. 7 | /// 8 | public enum LottieAnimationType 9 | { 10 | /// 11 | /// Creates clean SVG elements with proper viewBox handling. 12 | /// 13 | /// Best feature support and general purpose. 14 | [Description("svg")] 15 | Svg, 16 | 17 | /// 18 | /// Uses 2D context, clears canvas each frame, handles sizing automatically. 19 | /// 20 | /// Performance option for complex animations, typically better for full screen or 21 | /// large animations. 22 | [Description("canvas")] 23 | Canvas, 24 | 25 | /// 26 | /// Creates HTML elements with CSS transforms. 27 | /// 28 | /// Optional, generally slower with limited support for complex animations. 29 | [Description("html")] 30 | Html 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/wwwroot/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Blazor Lottie Player Documentation 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 |
Blazor Lottie Player
21 |
22 | 23 |
24 | An unhandled error has occurred. 25 | Reload 26 | 🗙 27 |
28 | 29 | 30 | 31 | 32 | 33 | 34 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Extensions/EnumExtensions.cs: -------------------------------------------------------------------------------- 1 | using System.ComponentModel; 2 | using System.Reflection; 3 | 4 | namespace Blazor.Lottie.Player; 5 | /// 6 | /// Provides extension methods for working with enumeration types. 7 | /// 8 | /// This class includes methods that enhance the functionality of enums, such as retrieving 9 | /// custom descriptions defined by the . 10 | internal static class EnumExtensions 11 | { 12 | /// 13 | /// Retrieves the description associated with an enumeration value. 14 | /// 15 | /// This method is useful for obtaining human-readable descriptions of enumeration 16 | /// values when the is used to provide metadata for the 17 | /// values. 18 | public static string ToDescription(this Enum value) 19 | { 20 | if (value == null) 21 | return string.Empty; 22 | 23 | var field = value.GetType().GetField(value.ToString()); 24 | if (field == null) 25 | return value.ToString(); 26 | 27 | var attribute = field.GetCustomAttribute(); 28 | return attribute?.Description ?? value.ToString(); 29 | } 30 | } 31 | 32 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Enums/LottieAnimationQuality.cs: -------------------------------------------------------------------------------- 1 | using System.ComponentModel; 2 | 3 | namespace Blazor.Lottie.Player; 4 | 5 | /// 6 | /// Specifies the rendering quality level for Lottie animations. 7 | /// 8 | /// 9 | /// Quality affects the precision of curve calculations and overall visual fidelity. 10 | /// Higher quality settings provide smoother curves and better visual accuracy but 11 | /// require more computational resources. 12 | /// 13 | public enum LottieAnimationQuality 14 | { 15 | /// 16 | /// Low quality rendering with basic curve precision. 17 | /// 18 | /// 19 | /// Fastest performance with reduced visual fidelity. Best for simple animations 20 | /// or when performance is critical (mobile devices, multiple simultaneous animations). 21 | /// 22 | [Description("low")] 23 | Low, 24 | 25 | /// 26 | /// Medium quality rendering with balanced precision and performance. 27 | /// 28 | /// 29 | /// Good balance between visual quality and performance. Suitable for most 30 | /// general-purpose animations and typical web applications. 31 | /// 32 | [Description("medium")] 33 | Medium, 34 | 35 | /// 36 | /// High quality rendering with maximum curve precision and visual fidelity. 37 | /// 38 | /// 39 | /// Best visual quality with smooth, precise curves. Use for detailed animations 40 | /// where visual perfection is important. May impact performance on lower-end devices. 41 | /// 42 | [Description("high")] 43 | High 44 | } 45 | -------------------------------------------------------------------------------- /tests/Blazor.Lottie.Player.UnitTests/Blazor.Lottie.Player.UnitTests.csproj: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | net9.0 5 | latest 6 | enable 7 | enable 8 | false 9 | Blazor.Lottie.Player.UnitTests 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | all 19 | runtime; build; native; contentfiles; analyzers; buildtransitive 20 | 21 | 22 | all 23 | runtime; build; native; contentfiles; analyzers; buildtransitive 24 | 25 | 26 | 27 | 28 | 29 | all 30 | runtime; build; native; contentfiles; analyzers; buildtransitive 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/wwwroot/loadLottieWeb.js: -------------------------------------------------------------------------------- 1 | export async function initialize(source) { 2 | try { 3 | if (window.lottie && typeof window.lottie === "object") { 4 | // Lottie is already loaded 5 | return true; 6 | } 7 | await injectJsLibrary(source); 8 | if (window.lottie && typeof window.lottie === "object") { 9 | return true; 10 | } 11 | return false; 12 | } 13 | catch (error) { 14 | console.error("Error initializing Lottie Web:", error); 15 | return false; 16 | } 17 | } 18 | 19 | export async function injectJsLibrary(source) { 20 | return new Promise((resolve, reject) => { 21 | if (document.querySelector("script[data-bodymovinjs]")) { 22 | // Already loaded 23 | if (window.lottie) { 24 | return resolve(); 25 | } 26 | return waitForLottie(resolve, reject); 27 | } 28 | // Check if lottie is already available globally 29 | if (window.lottie) { 30 | return resolve(); 31 | } 32 | const script = document.createElement("script"); 33 | script.setAttribute("data-bodymovinjs", "true"); 34 | script.type = "text/javascript"; 35 | script.src = source; 36 | 37 | script.onload = () => waitForLottie(resolve, reject); 38 | script.onerror = () => reject(new Error(`Failed to load ${source}`)); 39 | 40 | document.head.appendChild(script); 41 | }); 42 | } 43 | 44 | function waitForLottie(resolve, reject) { 45 | const start = Date.now(); 46 | const timeout = 1000; 47 | const interval = 25; 48 | 49 | function check() { 50 | if (window.lottie && typeof window.lottie === "object") { 51 | resolve(); 52 | } else if (Date.now() - start >= timeout) { 53 | console.error(`Lottie did not become available within ${timeout}ms, continuing load.`); 54 | resolve(); 55 | } else { 56 | setTimeout(check, interval); 57 | } 58 | } 59 | check(); 60 | } 61 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.sln: -------------------------------------------------------------------------------- 1 | 2 | Microsoft Visual Studio Solution File, Format Version 12.00 3 | # Visual Studio Version 17 4 | VisualStudioVersion = 17.14.36221.1 5 | MinimumVisualStudioVersion = 10.0.40219.1 6 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Blazor.Lottie.Player", "Blazor.Lottie.Player\Blazor.Lottie.Player.csproj", "{A256F3B7-5BA4-4CE4-80B8-B86B1240315B}" 7 | EndProject 8 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Blazor.Lottie.Player.Docs.WASM", "Blazor.Lottie.Player.Docs.WASM\Blazor.Lottie.Player.Docs.WASM.csproj", "{E701A428-9E74-4876-9752-703495976F01}" 9 | EndProject 10 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Blazor.Lottie.Player.UnitTests", "..\tests\Blazor.Lottie.Player.UnitTests\Blazor.Lottie.Player.UnitTests.csproj", "{31B59C97-E241-4555-B733-17DAD6362AAF}" 11 | EndProject 12 | Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "SolutionItems", "SolutionItems", "{02EA681E-C7D8-13C7-8484-4AC65E1B71E8}" 13 | ProjectSection(SolutionItems) = preProject 14 | ..\.editorconfig = ..\.editorconfig 15 | ..\README.md = ..\README.md 16 | Readme.txt = Readme.txt 17 | EndProjectSection 18 | EndProject 19 | Global 20 | GlobalSection(SolutionConfigurationPlatforms) = preSolution 21 | Debug|Any CPU = Debug|Any CPU 22 | Release|Any CPU = Release|Any CPU 23 | EndGlobalSection 24 | GlobalSection(ProjectConfigurationPlatforms) = postSolution 25 | {A256F3B7-5BA4-4CE4-80B8-B86B1240315B}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 26 | {A256F3B7-5BA4-4CE4-80B8-B86B1240315B}.Debug|Any CPU.Build.0 = Debug|Any CPU 27 | {A256F3B7-5BA4-4CE4-80B8-B86B1240315B}.Release|Any CPU.ActiveCfg = Release|Any CPU 28 | {A256F3B7-5BA4-4CE4-80B8-B86B1240315B}.Release|Any CPU.Build.0 = Release|Any CPU 29 | {E701A428-9E74-4876-9752-703495976F01}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 30 | {E701A428-9E74-4876-9752-703495976F01}.Debug|Any CPU.Build.0 = Debug|Any CPU 31 | {E701A428-9E74-4876-9752-703495976F01}.Release|Any CPU.ActiveCfg = Release|Any CPU 32 | {E701A428-9E74-4876-9752-703495976F01}.Release|Any CPU.Build.0 = Release|Any CPU 33 | {31B59C97-E241-4555-B733-17DAD6362AAF}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 34 | {31B59C97-E241-4555-B733-17DAD6362AAF}.Debug|Any CPU.Build.0 = Debug|Any CPU 35 | {31B59C97-E241-4555-B733-17DAD6362AAF}.Release|Any CPU.ActiveCfg = Release|Any CPU 36 | {31B59C97-E241-4555-B733-17DAD6362AAF}.Release|Any CPU.Build.0 = Release|Any CPU 37 | EndGlobalSection 38 | GlobalSection(SolutionProperties) = preSolution 39 | HideSolutionNode = FALSE 40 | EndGlobalSection 41 | GlobalSection(ExtensibilityGlobals) = postSolution 42 | SolutionGuid = {DB1F496D-F870-424A-8DFC-9E8F30D4F08F} 43 | EndGlobalSection 44 | EndGlobal 45 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | [![Sponsor](https://img.shields.io/badge/Sponsor-❤️_GitHub_Sponsors-orange?logo=github&style=for-the-badge)](https://github.com/sponsors/versile2) 2 | 3 | # Blazor Lottie Player 4 | 5 | Blazor Lottie Player makes it easy to integrate high-quality Lottie animations into your Blazor applications. 6 | 7 | ## 🚀 Getting Started 8 | 9 | ### 1. Install the NuGet Package 10 | 11 | Add [Blazor.Lottie.Player](https://mudx.org/docs/lottie) to your project via NuGet. 12 | 13 | ### 2. Choose How to Use the Component 14 | 15 | There are two ways to use Blazor Lottie Player: 16 | 17 | #### a. Using the Built-in Component 18 | 19 | - Add `@using Blazor.Lottie.Player` to your `_Imports.razor` file. 20 | - Use the `` component in your Razor files, setting the `Src` parameter to your Lottie animation JSON file. 21 | - The player will size itself to fill its parent container. Use CSS to control its width and height as needed. 22 | 23 | #### b. Using the Module Programmatically (Advanced) 24 | 25 | - Add `@using Blazor.Lottie.Player` to your `_Imports.razor` file. 26 | - Include the Lottie Web library (The LottiePlayer component loads it from the below CDN): 27 | 28 | ```html 29 | 30 | ``` 31 | 32 | - Instantiate and use the `LottiePlayer` class in your code-behind or component logic: 33 | 34 | ```csharp 35 | var player = new LottiePlayerModule(IJSRuntime, ElementReference); 36 | await player.InitializeAsync(LottiePlaybackOptions); 37 | // Optional Commands 38 | await player.PlayAsync(); 39 | await player.PauseAsync(); 40 | await player.StopAsync(); 41 | await player.GoToAndPlay(double frame, true); 42 | await player.GoToAndStop(double frame, true); 43 | await player.SetSpeedAsync(double speed, true); 44 | await player.SetDirectionAsync(LottieDirection.Forward); 45 | // Subscribe to Events 46 | player.OnAnimationLoaded += (args) => { /* Handle Animation Loaded */ }; 47 | player.OnDOMLoaded += (args) => { /* Handle DOM Loaded */ }; 48 | player.OnAnimationComplete += () => { /* Handle Animation Complete */ }; 49 | player.OnEnterFrame += (args) => { /* Handle Enter Frame */ }; 50 | player.OnComplete += () => { /* Handle Complete */ }; 51 | player.OnLoopComplete += () => { /* Handle Loop Complete */ }; 52 | ``` 53 | 54 | ### 3. Read the Docs 55 | 56 | Visit the [Blazor Lottie Player documentation](https://mudx.org/docs/lottie) for detailed usage instructions, examples, and API reference. 57 | 58 | ### 4. Get Help, Support, or Contribute 59 | 60 | If you need help, want to report an issue, or would like to support or contribute to the project, please visit the [GitHub repository](https://github.com/MudXtra/LottiePlayer) for more information. 61 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Component/LottiePlaybackOptions.cs: -------------------------------------------------------------------------------- 1 | 2 | namespace Blazor.Lottie.Player; 3 | /// 4 | /// Configuration options for Lottie animation playback and rendering. 5 | /// 6 | public class LottiePlaybackOptions 7 | { 8 | /// 9 | /// The source or path to the lottie animation JSON file. 10 | /// 11 | /// 12 | /// This can be a URL or a local path relative to the web root.
e.g. "./_content/Blazor.Lottie.Player/loading.json" 13 | ///
or "https://example.com/path/to/animation.json".
14 | ///
15 | public string Path { get; set; } = "./_content/Blazor.Lottie.Player/loading.json"; 16 | 17 | /// 18 | /// Gets or sets whether the animation should start playing automatically. 19 | /// 20 | /// Default is true. 21 | public bool AutoPlay { get; set; } = true; 22 | 23 | /// 24 | /// Gets or sets the type of Lottie animation to render. 25 | /// 26 | /// Default is SVG for best feature support. 27 | public string Renderer { get; set; } = LottieAnimationType.Svg.ToDescription(); 28 | 29 | /// 30 | /// Gets or sets the loop behavior for the animation. 31 | /// 32 | /// 33 | /// Can be true (infinite loop), false (no loop), or a positive integer 34 | /// for a specific number of loops. 35 | /// 36 | public object Loop { get; set; } = true; 37 | 38 | /// 39 | /// Gets or sets the playback direction. 40 | /// 41 | /// 1 for forward, -1 for reverse. Default is 1. 42 | public int Direction { get; set; } = (int)LottieAnimationDirection.Forward; 43 | 44 | /// 45 | /// Gets or sets the playback speed multiplier. 46 | /// 47 | /// 1.0 is normal speed, 2.0 is double speed, 0.5 is half speed. Default is 1.0. 48 | public double Speed { get; set; } = 1.0; 49 | 50 | /// 51 | /// Gets or sets whether to enable smooth frame interpolation for high refresh rate displays. 52 | /// 53 | /// Default is true for smooth animations. 54 | public bool SetSubFrame { get; set; } = true; 55 | 56 | /// 57 | /// Gets or sets the rendering quality level. 58 | /// 59 | /// Default is High. 60 | public string Quality { get; set; } = LottieAnimationQuality.High.ToDescription(); 61 | 62 | /// 63 | /// Whether to enable the enterFrame event. 64 | /// 65 | /// 66 | /// If CurrentFrameChangedFunc is null this should be false. 67 | /// 68 | public bool EnterFrameEvent { get; set; } = false; 69 | } 70 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Blazor.Lottie.Player.csproj: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | net8.0;net9.0 5 | enable 6 | enable 7 | 1.0.5 8 | 9 | 10 | 11 | Blazor.Lottie.Player 12 | Blazor.Lottie.Player 13 | MIT 14 | Nuget.png 15 | MudXtra 16 | Versile and Contributors 17 | Copyright 2025 MudXtra 18 | Blazor, Component, Blazor Components, Blazor Library, Lottie, Lottie Player, Lottie Animations 19 | A component wrapper to display Lottie Animations in Blazor. 20 | https://mudx.org/docs/lottieplayer 21 | README.md 22 | https://github.com/MudXtra/LottiePlayer 23 | git 24 | 25 | 26 | 27 | true 28 | true 29 | true 30 | snupkg 31 | 32 | 33 | 34 | true 35 | False 36 | true 37 | false 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | True 51 | \ 52 | 53 | 54 | True 55 | \ 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Configuration/LottieAnimationOptions.cs: -------------------------------------------------------------------------------- 1 | namespace Blazor.Lottie.Player; 2 | 3 | /// 4 | /// Represents the advanced configuration options for rendering Lottie animations. 5 | /// 6 | public class LottieAnimationOptions 7 | { 8 | /// 9 | /// Gets or sets the URL of the Lottie JavaScript library used for rendering Lottie animations. 10 | /// 11 | public string LottieSourceJs { get; set; } = "https://cdnjs.cloudflare.com/ajax/libs/lottie-web/5.13.0/lottie.min.js"; 12 | 13 | /// 14 | /// Gets or sets the quality level of the Lottie animation rendering. This is a global setting. 15 | /// 16 | /// Defaults to . Higher quality levels may 17 | /// result in smoother animations but could increase resource usage. 18 | public LottieAnimationQuality AnimationQuality { get; set; } = LottieAnimationQuality.High; 19 | 20 | /// 21 | /// Gets or sets whether to enable smooth frame interpolation for high refresh rate displays. 22 | /// 23 | /// 24 | /// When true (default), the animation will interpolate between keyframes to create 25 | /// smooth motion that adapts to your display's refresh rate (60Hz, 120Hz, etc.). 26 | /// When false, the animation will only update on the original After Effects keyframes, 27 | /// which may appear choppy on high refresh displays but offers better performance and 28 | /// pixel-perfect reproduction of the original animation timing. 29 | /// 30 | public bool SmoothFrameInterpolation { get; set; } = true; 31 | 32 | /// 33 | /// Determines whether the specified object is equal to the current instance. 34 | /// 35 | /// Two instances are considered equal if they have the same , , and values. 37 | /// The object to compare with the current instance. 38 | /// if the specified object is equal to the current instance; otherwise, . 40 | public override bool Equals(object? obj) 41 | { 42 | if (ReferenceEquals(this, obj)) 43 | return true; 44 | if (obj is not LottieAnimationOptions other) 45 | return false; 46 | 47 | return string.Equals(LottieSourceJs, other.LottieSourceJs, StringComparison.Ordinal) 48 | && AnimationQuality == other.AnimationQuality 49 | && SmoothFrameInterpolation == other.SmoothFrameInterpolation; 50 | } 51 | 52 | /// 53 | /// Returns a hash code for the current object. 54 | /// 55 | /// The hash code is computed based on the values of the , , and properties. This ensures that objects 57 | /// with the same property values produce the same hash code. 58 | /// An integer hash code that represents the current object. 59 | public override int GetHashCode() 60 | { 61 | return HashCode.Combine( 62 | LottieSourceJs != null ? StringComparer.Ordinal.GetHashCode(LottieSourceJs) : 0, 63 | AnimationQuality, 64 | SmoothFrameInterpolation 65 | ); 66 | } 67 | } 68 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/wwwroot/css/app.css: -------------------------------------------------------------------------------- 1 | .valid.modified:not([type=checkbox]) { 2 | outline: 1px solid #26b050; 3 | } 4 | 5 | .invalid { 6 | outline: 1px solid red; 7 | } 8 | 9 | .validation-message { 10 | color: red; 11 | } 12 | 13 | #blazor-error-ui { 14 | color-scheme: light only; 15 | background: lightyellow; 16 | bottom: 0; 17 | box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2); 18 | box-sizing: border-box; 19 | display: none; 20 | left: 0; 21 | padding: 0.6rem 1.25rem 0.7rem 1.25rem; 22 | position: fixed; 23 | width: 100%; 24 | z-index: 1000; 25 | } 26 | 27 | #blazor-error-ui .dismiss { 28 | cursor: pointer; 29 | position: absolute; 30 | right: 0.75rem; 31 | top: 0.5rem; 32 | } 33 | 34 | .blazor-error-boundary { 35 | background: url() no-repeat 1rem/1.8rem, #b32121; 36 | padding: 1rem 1rem 1rem 3.7rem; 37 | color: white; 38 | } 39 | 40 | .blazor-error-boundary::after { 41 | content: "An error has occurred." 42 | } 43 | 44 | .loading-progress { 45 | position: relative; 46 | display: block; 47 | width: 8rem; 48 | height: 8rem; 49 | margin: 20vh auto 1rem auto; 50 | } 51 | 52 | .loading-progress circle { 53 | fill: none; 54 | stroke: #e0e0e0; 55 | stroke-width: 0.6rem; 56 | transform-origin: 50% 50%; 57 | transform: rotate(-90deg); 58 | } 59 | 60 | .loading-progress circle:last-child { 61 | stroke: #1b6ec2; 62 | stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%; 63 | transition: stroke-dasharray 0.05s ease-in-out; 64 | } 65 | 66 | .loading-progress-text { 67 | position: absolute; 68 | text-align: center; 69 | font-weight: bold; 70 | inset: calc(20vh + 3.25rem) 0 auto 0.2rem; 71 | } 72 | 73 | .loading-progress-text:after { 74 | content: var(--blazor-load-percentage-text, "Loading"); 75 | } 76 | 77 | code { 78 | color: #c02d76; 79 | } 80 | 81 | .form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder { 82 | color: var(--bs-secondary-color); 83 | text-align: end; 84 | } 85 | 86 | .form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder { 87 | text-align: start; 88 | } -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Player-API-Documentation.txt: -------------------------------------------------------------------------------- 1 | https://airbnb.io/lottie/#/web 2 | ** Lottie BodyMovin Version 5.13.0 ** 3 | Getting Started 4 | 5 | Bodymovin can render Lottie JSON files on the web. 6 | 7 | First, get the bodymovin player javascript library. It is statically hosted at https://cdnjs.com/libraries/bodymovin or you can get the javascript directly by clicking Get Player in the bodymovin plugin. 8 | 9 | 10 | 11 | 12 | 13 | Bodymovin is also available on npm and bower. 14 | 15 | Then playing the animation is as simple as: 16 | 17 | var animation = bodymovin.loadAnimation({ 18 | container: document.getElementById('lottie'), // Required 19 | path: 'data.json', // Required 20 | renderer: 'svg/canvas/html', // Required 21 | loop: true, // Optional 22 | autoplay: true, // Optional 23 | name: "Hello World", // Name for future reference. Optional. 24 | }) 25 | 26 | HTML player installation 27 | Static URL 28 | 29 | Or you can use the script file from here: https://cdnjs.com/libraries/lottie-web 30 | 31 | Usage 32 | 33 | Call lottie.loadAnimation() to start an animation. It takes an object as a unique param with: 34 | 35 | animationData: an Object with the exported animation data. 36 | path: the relative path to the animation object. (animationData and path are mutually exclusive) 37 | loop: true / false / number 38 | autoplay: true / false it will start playing as soon as it is ready 39 | name: animation name for future reference 40 | renderer: 'svg' / 'canvas' / 'html' to set the renderer 41 | container: the dom element on which to render the animation 42 | 43 | It returns the animation instance you can control with play, pause, setSpeed, etc. 44 | 45 | lottie.loadAnimation({ 46 | container: element, // the dom element that will contain the animation 47 | renderer: 'svg', 48 | loop: true, 49 | autoplay: true, 50 | path: 'data.json' // the path to the animation json 51 | }); 52 | 53 | Usage 54 | 55 | animation instances have these main methods: 56 | 57 | anim.play() 58 | anim.stop() 59 | anim.pause() 60 | anim.setLocationHref(locationHref) -- one param usually pass as location.href. Its useful when you experience mask issue in safari where your url does not have # symbol. 61 | anim.setSpeed(speed) -- one param speed (1 is normal speed) 62 | anim.goToAndStop(value, isFrame) first param is a numeric value. second param is a boolean that defines time or frames for first param 63 | anim.goToAndPlay(value, isFrame) first param is a numeric value. second param is a boolean that defines time or frames for first param 64 | anim.setDirection(direction) -- one param direction (1 is normal direction.) 65 | anim.playSegments(segments, forceFlag) -- first param is a single array or multiple arrays of two values each(fromFrame,toFrame), second param is a boolean for forcing the new segment right away 66 | anim.setSubframe(flag) -- If false, it will respect the original AE fps. If true, it will update as much as possible. (true by default 67 | anim.destroy() 68 | 69 | lottie has 8 main methods: 70 | 71 | lottie.play() -- with 1 optional parameter name to target a specific animation 72 | lottie.stop() -- with 1 optional parameter name to target a specific animation 73 | lottie.setSpeed() -- first param speed (1 is normal speed) -- with 1 optional parameter name to target a specific animation 74 | lottie.setDirection() -- first param direction (1 is normal direction.) -- with 1 optional parameter name to target a specific animation 75 | lottie.searchAnimations() -- looks for elements with class "lottie" 76 | lottie.loadAnimation() -- Explained above. returns an animation instance to control individually. 77 | lottie.destroy() -- To destroy and release resources. The DOM element will be emptied. 78 | lottie.registerAnimation() -- you can register an element directly with registerAnimation. It must have the "data-animation-path" attribute pointing at the data.json url 79 | lottie.setQuality() -- default 'high', set 'high','medium','low', or a number > 1 to improve player performance. In some animations as low as 2 won't show any difference. 80 | 81 | Events 82 | 83 | onComplete 84 | onLoopComplete 85 | onEnterFrame 86 | onSegmentStart 87 | 88 | you can also use addEventListener with the following events: 89 | 90 | complete 91 | loopComplete 92 | enterFrame 93 | segmentStart 94 | config_ready (when initial config is done) 95 | data_ready (when all parts of the animation have been loaded) 96 | DOMLoaded (when elements have been added to the DOM) 97 | destroy 98 | -------------------------------------------------------------------------------- /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | indent_style = space 5 | end_of_line = crlf 6 | charset = utf-8 7 | indent_size = 4 8 | trim_trailing_whitespace = true 9 | insert_final_newline = true 10 | csharp_using_directive_placement = outside_namespace:silent 11 | csharp_prefer_simple_using_statement = true:suggestion 12 | csharp_prefer_braces = true:silent 13 | csharp_style_namespace_declarations = file_scoped:silent 14 | csharp_style_prefer_method_group_conversion = true:silent 15 | csharp_style_prefer_top_level_statements = true:silent 16 | csharp_style_prefer_primary_constructors = true:suggestion 17 | csharp_prefer_system_threading_lock = true:suggestion 18 | csharp_style_expression_bodied_methods = false:silent 19 | csharp_style_expression_bodied_constructors = false:silent 20 | csharp_style_expression_bodied_operators = false:silent 21 | csharp_style_expression_bodied_properties = true:silent 22 | csharp_style_expression_bodied_indexers = true:silent 23 | csharp_style_expression_bodied_accessors = true:silent 24 | csharp_style_expression_bodied_lambdas = true:silent 25 | csharp_style_expression_bodied_local_functions = false:silent 26 | csharp_indent_labels = one_less_than_current 27 | 28 | [*.json] 29 | indent_style = space 30 | end_of_line = crlf 31 | charset = utf-8 32 | indent_size = 2 33 | 34 | [*.{yml,yaml}] 35 | indent_style = space 36 | end_of_line = crlf 37 | charset = utf-8 38 | indent_size = 2 39 | 40 | [*.md] 41 | trim_trailing_whitespace = false 42 | insert_final_newline = false 43 | 44 | [*.{cs,vb}] 45 | #### Naming styles #### 46 | 47 | # Naming rules 48 | 49 | dotnet_naming_rule.interface_should_be_begins_with_i.severity = suggestion 50 | dotnet_naming_rule.interface_should_be_begins_with_i.symbols = interface 51 | dotnet_naming_rule.interface_should_be_begins_with_i.style = begins_with_i 52 | 53 | dotnet_naming_rule.types_should_be_pascal_case.severity = suggestion 54 | dotnet_naming_rule.types_should_be_pascal_case.symbols = types 55 | dotnet_naming_rule.types_should_be_pascal_case.style = pascal_case 56 | 57 | dotnet_naming_rule.non_field_members_should_be_pascal_case.severity = suggestion 58 | dotnet_naming_rule.non_field_members_should_be_pascal_case.symbols = non_field_members 59 | dotnet_naming_rule.non_field_members_should_be_pascal_case.style = pascal_case 60 | dotnet_diagnostic.IDE0130.severity = none 61 | 62 | # Symbol specifications 63 | 64 | dotnet_naming_symbols.interface.applicable_kinds = interface 65 | dotnet_naming_symbols.interface.applicable_accessibilities = public, internal, private, protected, protected_internal, private_protected 66 | dotnet_naming_symbols.interface.required_modifiers = 67 | 68 | dotnet_naming_symbols.types.applicable_kinds = class, struct, interface, enum 69 | dotnet_naming_symbols.types.applicable_accessibilities = public, internal, private, protected, protected_internal, private_protected 70 | dotnet_naming_symbols.types.required_modifiers = 71 | 72 | dotnet_naming_symbols.non_field_members.applicable_kinds = property, event, method 73 | dotnet_naming_symbols.non_field_members.applicable_accessibilities = public, internal, private, protected, protected_internal, private_protected 74 | dotnet_naming_symbols.non_field_members.required_modifiers = 75 | 76 | # Naming styles 77 | 78 | dotnet_naming_style.begins_with_i.required_prefix = I 79 | dotnet_naming_style.begins_with_i.required_suffix = 80 | dotnet_naming_style.begins_with_i.word_separator = 81 | dotnet_naming_style.begins_with_i.capitalization = pascal_case 82 | 83 | dotnet_naming_style.pascal_case.required_prefix = 84 | dotnet_naming_style.pascal_case.required_suffix = 85 | dotnet_naming_style.pascal_case.word_separator = 86 | dotnet_naming_style.pascal_case.capitalization = pascal_case 87 | 88 | dotnet_naming_style.pascal_case.required_prefix = 89 | dotnet_naming_style.pascal_case.required_suffix = 90 | dotnet_naming_style.pascal_case.word_separator = 91 | dotnet_naming_style.pascal_case.capitalization = pascal_case 92 | dotnet_style_coalesce_expression = true:suggestion 93 | dotnet_style_null_propagation = true:suggestion 94 | dotnet_style_prefer_is_null_check_over_reference_equality_method = true:suggestion 95 | dotnet_style_prefer_auto_properties = true:silent 96 | dotnet_style_object_initializer = true:suggestion 97 | dotnet_style_collection_initializer = true:suggestion 98 | dotnet_style_prefer_simplified_boolean_expressions = true:suggestion 99 | dotnet_style_prefer_conditional_expression_over_assignment = true:silent 100 | dotnet_style_prefer_conditional_expression_over_return = true:silent 101 | dotnet_style_explicit_tuple_names = true:suggestion 102 | dotnet_style_prefer_inferred_tuple_names = true:suggestion 103 | dotnet_style_prefer_inferred_anonymous_type_member_names = true:suggestion 104 | dotnet_style_prefer_compound_assignment = true:suggestion 105 | dotnet_style_operator_placement_when_wrapping = beginning_of_line 106 | tab_width = 4 107 | dotnet_style_prefer_simplified_interpolation = true:suggestion 108 | dotnet_style_namespace_match_folder = true:suggestion 109 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/wwwroot/lottiePlayerModule.js: -------------------------------------------------------------------------------- 1 | 2 | export function initialize(dotNetRef, elementRef, options) { 3 | const animation = lottie.loadAnimation({ 4 | container: elementRef, 5 | renderer: options.renderer, 6 | loop: options.loop, 7 | autoplay: false, 8 | path: options.path 9 | }); 10 | let success = animation !== null && animation !== undefined; 11 | if (!success) { 12 | console.error("Failed to load Lottie animation. Check the path and options."); 13 | return null; 14 | } 15 | 16 | // Set up options 17 | success = setOptions(animation, options); 18 | if (!success) { 19 | console.error("Failed to set options for Lottie animation."); 20 | return null; 21 | } 22 | // Set up event listeners 23 | success = addEvents(animation, dotNetRef, options, elementRef); 24 | if (!success) { 25 | console.error("Failed to add event listeners for Lottie animation."); 26 | return null; 27 | } 28 | // start playing the animation if autoplay is true 29 | if (options.autoPlay) { 30 | // If autoplay is true, play the animation immediately 31 | animation.play(); 32 | } 33 | return animation; // Return animation if successful 34 | } 35 | 36 | function setOptions(animation, options) { 37 | if (animation && options) { 38 | // Apply various options 39 | if (options.speed !== undefined && options.speed !== 1.0) animation.setSpeed(options.speed); 40 | if (options.direction !== undefined && options.direction !== 1) animation.setDirection(options.direction); 41 | if (options.setSubFrame !== true) animation.setSubframe(false); 42 | if (options.quality !== undefined && options.quality !== 'high') lottie.setQuality(options.quality); 43 | return true; 44 | } 45 | return false; 46 | } 47 | 48 | function addEvents(animation, dotNetAdapter, options, elementRef) { 49 | if (animation && dotNetAdapter && options && elementRef) { 50 | animation.addEventListener('data_ready', () => { 51 | // Add event listeners 52 | const eventArgs = { 53 | elementId: elementRef.id, 54 | currentFrame: animation.currentFrame, 55 | totalFrames: animation.totalFrames 56 | }; 57 | invokeDotNetMethodAsync(dotNetAdapter, "AnimationReadyEvent", eventArgs); 58 | }); 59 | animation.addEventListener('DOMLoaded', () => { 60 | // Add event listeners 61 | const eventArgs = { 62 | elementId: elementRef.id, 63 | currentFrame: animation.currentFrame, 64 | totalFrames: animation.totalFrames 65 | }; 66 | invokeDotNetMethodAsync(dotNetAdapter, "DOMLoadedEvent", eventArgs); 67 | }); 68 | animation.addEventListener('complete', () => { 69 | invokeDotNetMethodAsync(dotNetAdapter, 'CompleteEvent'); 70 | }); 71 | animation.addEventListener('loopComplete', () => { 72 | invokeDotNetMethodAsync(dotNetAdapter, 'LoopCompleteEvent'); 73 | }); 74 | if (options.enterFrameEvent) { 75 | animation.addEventListener('enterFrame', (e) => { 76 | invokeDotNetMethodAsync(dotNetAdapter, 'EnterFrameEvent', e); 77 | }); 78 | } 79 | return true; 80 | } 81 | return false; 82 | } 83 | 84 | function invokeDotNetMethodAsync(dotNetAdapter, methodName, ...args) { 85 | return dotNetAdapter.invokeMethodAsync(methodName, ...args) 86 | .catch((reason) => { 87 | console.error(reason); 88 | }); 89 | } 90 | 91 | export function play(animation) { 92 | if (animation) { 93 | animation.play(); 94 | } else { 95 | console.error("Animation instance is null or undefined."); 96 | } 97 | } 98 | 99 | export function stop(animation) { 100 | if (animation) { 101 | animation.stop(); 102 | } else { 103 | console.error("Animation instance is null or undefined."); 104 | } 105 | } 106 | 107 | export function pause(animation) { 108 | if (animation) { 109 | animation.pause(); 110 | } else { 111 | console.error("Animation instance is null or undefined."); 112 | } 113 | } 114 | 115 | export function goToAndStop(animation, frame, isFrame) { 116 | if (animation) { 117 | if (isFrame) { 118 | animation.goToAndStop(frame, true); 119 | } else { 120 | animation.goToAndStop(animation.totalFrames * frame, true); 121 | } 122 | } else { 123 | console.error("Animation instance is null or undefined."); 124 | } 125 | } 126 | 127 | export function goToAndPlay(animation, frame, isFrame) { 128 | if (animation) { 129 | if (isFrame) { 130 | animation.goToAndPlay(frame, true); 131 | } else { 132 | animation.goToAndPlay(animation.totalFrames * frame, true); 133 | } 134 | } else { 135 | console.error("Animation instance is null or undefined."); 136 | } 137 | } 138 | 139 | export function setDirection(animation, direction) { 140 | if (animation && (direction === 1 || direction === -1)) { 141 | animation.setDirection(direction); 142 | } else { 143 | console.error("Invalid animation instance or direction value. Direction must be 1 or -1."); 144 | } 145 | } 146 | 147 | export function setSpeed(animation, speed) { 148 | if (animation && speed > 0) { 149 | animation.setSpeed(speed); 150 | } else { 151 | console.error("Invalid animation instance or speed value. Speed must be greater than 0."); 152 | } 153 | } 154 | 155 | export function destroy(animation) { 156 | if (animation) { 157 | animation.destroy(); 158 | } else { 159 | console.error("Animation instance is null or undefined."); 160 | } 161 | } 162 | -------------------------------------------------------------------------------- /tests/Blazor.Lottie.Player.UnitTests/LottieModuleTests.cs: -------------------------------------------------------------------------------- 1 | using AwesomeAssertions; 2 | using Bunit; 3 | using Moq; 4 | 5 | namespace Blazor.Lottie.Player.UnitTests; 6 | public class LottieModuleTests : BunitTest 7 | { 8 | [SetUp] 9 | public override void Setup() 10 | { 11 | base.Setup(); 12 | 13 | // Setup the import call to return a mock module 14 | var moduleMock = Context.JSInterop.SetupModule("./_content/Blazor.Lottie.Player/loadLottieWeb.js"); 15 | // Setup the initialize call to return true 16 | moduleMock.Setup("initialize", _ => true).SetResult(true); 17 | 18 | var lottieModuleMock = Context.JSInterop.SetupModule("./_content/Blazor.Lottie.Player/lottiePlayerModule.js"); 19 | lottieModuleMock.Setup("initialize", _ => true).SetResult(true); 20 | 21 | lottieModuleMock.Setup("play", _ => true).SetResult(true); 22 | lottieModuleMock.Setup("pause", _ => true).SetResult(true); 23 | lottieModuleMock.Setup("stop", _ => true).SetResult(true); 24 | lottieModuleMock.Setup("destroy", _ => true).SetResult(true); 25 | lottieModuleMock.Setup("setSpeed", _ => true).SetResult(true); 26 | lottieModuleMock.Setup("setDirection", _ => true).SetResult(true); 27 | } 28 | 29 | [Test] 30 | public void LottiePlayerModule_Initialization() 31 | { 32 | var comp = Context.RenderComponent(parameters => parameters 33 | .Add(p => p.Src, "https://example.com/lottie.json") 34 | ); 35 | 36 | var lottieModule = comp.Instance.LottiePlayerModule; 37 | lottieModule.Should().NotBeNull(); 38 | 39 | lottieModule._lottieAnimationRef.Should().NotBeNull(); 40 | 41 | // after init, jsruntime, elementref, and dotnetobjectref should be setup 42 | lottieModule._js.Should().NotBeNull(); 43 | lottieModule._elementRef.Should().NotBeNull(); 44 | lottieModule._dotNetReference.Should().NotBeNull(); 45 | lottieModule._isDisposing.Should().BeFalse(); 46 | 47 | // verify element ref 48 | lottieModule._elementRef.Should().NotBeNull(); 49 | } 50 | 51 | [Test] 52 | public void LottiePlayerModule_Events() 53 | { 54 | var comp = Context.RenderComponent(parameters => parameters 55 | .Add(p => p.Src, "https://example.com/lottie.json") 56 | ); 57 | 58 | var lottieModule = comp.Instance.LottiePlayerModule; 59 | lottieModule.Should().NotBeNull(); 60 | 61 | var loadedEventArgs = new LottiePlayerLoadedEventArgs 62 | { 63 | ElementId = comp.Instance.ElementId, 64 | CurrentFrame = 0.0, 65 | TotalFrames = 100.0, 66 | }; 67 | 68 | var eventTriggered = false; 69 | lottieModule.OnDOMLoaded += (sender, args) => eventTriggered = true; 70 | comp.InvokeAsync(() => lottieModule.DOMLoadedEvent(loadedEventArgs)); 71 | eventTriggered.Should().BeTrue(); 72 | 73 | eventTriggered = false; 74 | lottieModule.OnAnimationReady += (sender, args) => eventTriggered = true; 75 | comp.InvokeAsync(() => lottieModule.AnimationReadyEvent(loadedEventArgs)); 76 | eventTriggered.Should().BeTrue(); 77 | 78 | eventTriggered = false; 79 | lottieModule.OnEnterFrame += (sender, args) => eventTriggered = true; 80 | comp.InvokeAsync(() => lottieModule.EnterFrameEvent(new LottiePlayerEventFrameArgs() { CurrentTime = 23.7 })); 81 | eventTriggered.Should().BeTrue(); 82 | 83 | eventTriggered = false; 84 | lottieModule.OnComplete += (sender, args) => eventTriggered = true; 85 | comp.InvokeAsync(() => lottieModule.CompleteEvent()); 86 | eventTriggered.Should().BeTrue(); 87 | 88 | eventTriggered = false; 89 | lottieModule.OnLoopComplete += (sender, args) => eventTriggered = true; 90 | comp.InvokeAsync(() => lottieModule.LoopCompleteEvent()); 91 | eventTriggered.Should().BeTrue(); 92 | } 93 | 94 | [Test] 95 | public async Task LottiePlayerModule_Actions() 96 | { 97 | var comp = Context.RenderComponent(parameters => parameters 98 | .Add(p => p.Src, "https://example.com/lottie.json") 99 | .Add(p => p.AutoPlay, false) 100 | ); 101 | 102 | var lottieModule = comp.Instance.LottiePlayerModule; 103 | lottieModule.Should().NotBeNull(); 104 | 105 | // Test play 106 | await lottieModule.PlayAsync(); 107 | Context.JSInterop.VerifyInvoke("play"); 108 | 109 | // Test pause 110 | await lottieModule.PauseAsync(); 111 | Context.JSInterop.VerifyInvoke("pause"); 112 | 113 | // Test stop 114 | await lottieModule.StopAsync(); 115 | Context.JSInterop.VerifyInvoke("stop"); 116 | 117 | // Test set speed 118 | await lottieModule.SetSpeedAsync(1.5); 119 | Context.JSInterop.VerifyInvoke("setSpeed"); 120 | 121 | // Test set direction 122 | await lottieModule.SetDirectionAsync(LottieAnimationDirection.Forward); 123 | Context.JSInterop.VerifyInvoke("setDirection"); 124 | } 125 | 126 | [Test] 127 | public async Task LottiePlayerModule_Dispose() 128 | { 129 | var comp = Context.RenderComponent(parameters => parameters 130 | .Add(p => p.Src, "https://example.com/lottie.json") 131 | .Add(p => p.AutoPlay, false) 132 | ); 133 | var lottieModule = comp.Instance.LottiePlayerModule; 134 | lottieModule.Should().NotBeNull(); 135 | // Dispose the module 136 | await lottieModule.DisposeAsync(); 137 | lottieModule._isDisposing.Should().BeTrue(); 138 | lottieModule._lottieAnimationRef.Should().BeNull(); 139 | 140 | // test CanExecute returns false after dispose 141 | lottieModule.CanExecute.Should().BeFalse(); 142 | var eventTriggered = false; 143 | 144 | // test actions can't execute after dispose 145 | await lottieModule.PlayAsync(); 146 | Context.JSInterop.VerifyNotInvoke("play"); 147 | await lottieModule.PauseAsync(); 148 | Context.JSInterop.VerifyNotInvoke("pause"); 149 | await lottieModule.StopAsync(); 150 | Context.JSInterop.VerifyNotInvoke("stop"); 151 | await lottieModule.SetSpeedAsync(1.5); 152 | Context.JSInterop.VerifyNotInvoke("setSpeed"); 153 | await lottieModule.SetDirectionAsync(LottieAnimationDirection.Forward); 154 | Context.JSInterop.VerifyNotInvoke("setDirection"); 155 | 156 | // test events can't trigger after dispose 157 | lottieModule.OnDOMLoaded += (sender, args) => eventTriggered = true; 158 | await lottieModule.DOMLoadedEvent(It.IsAny()); 159 | eventTriggered.Should().BeFalse(); 160 | lottieModule.OnAnimationReady += (sender, args) => eventTriggered = true; 161 | await lottieModule.AnimationReadyEvent(It.IsAny()); 162 | eventTriggered.Should().BeFalse(); 163 | lottieModule.OnEnterFrame += (sender, args) => eventTriggered = true; 164 | await lottieModule.EnterFrameEvent(new LottiePlayerEventFrameArgs()); 165 | eventTriggered.Should().BeFalse(); 166 | lottieModule.OnComplete += (sender, args) => eventTriggered = true; 167 | await lottieModule.CompleteEvent(); 168 | eventTriggered.Should().BeFalse(); 169 | lottieModule.OnLoopComplete += (sender, args) => eventTriggered = true; 170 | await lottieModule.LoopCompleteEvent(); 171 | eventTriggered.Should().BeFalse(); 172 | 173 | Context.JSInterop.VerifyInvoke("destroy"); 174 | } 175 | } 176 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/Pages/Home.razor: -------------------------------------------------------------------------------- 1 | @page "/" 2 | @inject ISnackbar Snackbar 3 | 4 | Blazor Lottie Player Documentation 5 | 6 |

Blazor Lottie Player

7 | 8 |

Welcome to the Blazor Lottie Player Documentation.

9 | 10 |

This is a simple Blazor WebAssembly application that demonstrates how to use the 11 | Blazor Lottie Player component. The Lottie Player component allows you to easily 12 | integrate Lottie animations into your Blazor applications without regard to what 13 | UI components you might be using.

14 | 15 |

To get started, you can check out

16 | 17 | Copyright @@ 2025 MudXtra 18 | 19 | 20 | 21 | Example 1: Basic Controls 22 |
23 | 24 |
25 | 26 | Play 27 | Pause 28 | Stop 29 | 30 |
31 | 32 | 33 | 34 | Example 2: Autoplay, Loop, and Speed 35 |
36 | 41 |
42 | 43 | 44 | 45 | 46 | Speed: @_speed2.ToString("0.0")x 47 | 48 |
49 | 50 | 51 | 52 | Example 3: Direction Control 53 |
54 | 57 |
58 | 59 | 60 | Forward 61 | Reverse 62 | 63 | Frame: @_lottiePlayer3?.CurrentAnimationFrame of @_lottiePlayer3!.TotalAnimationFrames 64 | Set Direction 65 | 66 |
67 | 68 | 69 | 70 | Example 4: Responsive Sizing 71 |
72 | 74 |
75 | 76 | Size: @_size4 px 77 |
78 | 79 | 80 | 81 | Example 5: Disabled State 82 |
83 | 86 |
87 | 88 | 89 | @foreach (var lottie in _lottieList.OrderBy(x => x.Name)) 90 | { 91 | @lottie.Name 92 | } 93 | 94 | 95 | 96 | Add 97 | 98 |
99 | 100 | @code { 101 | private List _lottieList = []; 102 | 103 | // Example 1 104 | LottiePlayer? _lottiePlayer1; 105 | int _lottie1Sel = 1; 106 | 107 | // Example 2 108 | LottiePlayer? _lottiePlayer2; 109 | bool _autoplay2 = true; 110 | bool _loop2 = true; 111 | double _speed2 = 1.0; 112 | int _lottie2Sel = 2; 113 | 114 | // Example 3 115 | LottiePlayer? _lottiePlayer3; 116 | int _direction3 = 1; 117 | int _lottie3Sel = 3; 118 | 119 | // Example 4 120 | LottiePlayer? _lottiePlayer4; 121 | int _size4 = 300; 122 | string _size4px => $"{_size4}px"; 123 | string _lottieName = string.Empty; 124 | string _lottieSrc = string.Empty; 125 | LottieAnimationList _lottieAnim = default!; 126 | 127 | // Legacy example 128 | LottiePlayer? _lottiePlayer; 129 | int _lottie5Sel = 0; 130 | 131 | protected override void OnInitialized() 132 | { 133 | _lottieList.Add(new LottieAnimationList() { Name = "Hand Loading", Src = "https://lottie.host/99ab6923-62d6-4030-aeb0-282d33242f3e/Z1CzIUWU18.json" }); 134 | _lottieList.Add(new LottieAnimationList() { Name = "Gift Box", Src = "./lottie/newAnimation.json" }); 135 | _lottieList.Add(new LottieAnimationList() { Name = "Lego Loading", Src = "https://lottie.host/694149cc-b526-4803-acff-522c384f3319/UM1M0cO0TD.json" }); 136 | _lottieList.Add(new LottieAnimationList() { Name = "Handshake", Src = "https://lottie.host/382bbcd7-e7b1-4a30-90cd-884a9c7c3bb1/F7I9nPKEr1.json" }); 137 | _lottieList.Add(new LottieAnimationList() { Name = "HotDog Loading", Src = "./lottie/BunBun.json" }); 138 | _lottieList.Add(new LottieAnimationList() { Name = "Hand Loading JSON", Src = "./lottie/loading.json" }); 139 | _lottieAnim = _lottieList[4]; 140 | } 141 | 142 | private void AddLottie(MouseEventArgs args) 143 | { 144 | if (!string.IsNullOrWhiteSpace(_lottieName) && !string.IsNullOrWhiteSpace(_lottieSrc)) 145 | { 146 | _lottieList.Add(new LottieAnimationList() { Name = _lottieName, Src = _lottieSrc }); 147 | _lottieName = string.Empty; 148 | _lottieSrc = string.Empty; 149 | Snackbar.Add("Lottie animation added successfully!", Severity.Success); 150 | } 151 | else 152 | { 153 | Snackbar.Add("Please provide both name and source URL for the Lottie animation.", Severity.Error); 154 | } 155 | } 156 | 157 | private void LottiePlayer_OnCurrentFrameChanged(LottiePlayerEventFrameArgs e) 158 | { 159 | if (e.CurrentTime > 99999999) 160 | { 161 | Snackbar.Add("Current time exceeds the maximum limit.", Severity.Warning); 162 | } 163 | } 164 | } 165 | 166 | @code { 167 | public class LottieAnimationList 168 | { 169 | public string Name { get; set; } = string.Empty; 170 | public string Src { get; set; } = string.Empty; 171 | public override string ToString() 172 | { 173 | return $"{Name}"; 174 | } 175 | } 176 | } 177 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | ## Ignore Visual Studio temporary files, build results, and 2 | ## files generated by popular Visual Studio add-ons. 3 | ## 4 | ## Get latest from https://github.com/github/gitignore/blob/main/VisualStudio.gitignore 5 | 6 | # User-specific files 7 | *.rsuser 8 | *.suo 9 | *.user 10 | *.userosscache 11 | *.sln.docstates 12 | 13 | # User-specific files (MonoDevelop/Xamarin Studio) 14 | *.userprefs 15 | 16 | # Mono auto generated files 17 | mono_crash.* 18 | 19 | # Build results 20 | [Dd]ebug/ 21 | [Dd]ebugPublic/ 22 | [Rr]elease/ 23 | [Rr]eleases/ 24 | x64/ 25 | x86/ 26 | [Ww][Ii][Nn]32/ 27 | [Aa][Rr][Mm]/ 28 | [Aa][Rr][Mm]64/ 29 | bld/ 30 | [Bb]in/ 31 | [Oo]bj/ 32 | [Ll]og/ 33 | [Ll]ogs/ 34 | 35 | # Visual Studio 2015/2017 cache/options directory 36 | .vs/ 37 | # Uncomment if you have tasks that create the project's static files in wwwroot 38 | #wwwroot/ 39 | 40 | # Visual Studio 2017 auto generated files 41 | Generated\ Files/ 42 | 43 | # MSTest test Results 44 | [Tt]est[Rr]esult*/ 45 | [Bb]uild[Ll]og.* 46 | 47 | # NUnit 48 | *.VisualState.xml 49 | TestResult.xml 50 | nunit-*.xml 51 | 52 | # Build Results of an ATL Project 53 | [Dd]ebugPS/ 54 | [Rr]eleasePS/ 55 | dlldata.c 56 | 57 | # Benchmark Results 58 | BenchmarkDotNet.Artifacts/ 59 | 60 | # .NET Core 61 | project.lock.json 62 | project.fragment.lock.json 63 | artifacts/ 64 | 65 | # ASP.NET Scaffolding 66 | ScaffoldingReadMe.txt 67 | 68 | # StyleCop 69 | StyleCopReport.xml 70 | 71 | # Files built by Visual Studio 72 | *_i.c 73 | *_p.c 74 | *_h.h 75 | *.ilk 76 | *.meta 77 | *.obj 78 | *.iobj 79 | *.pch 80 | *.pdb 81 | *.ipdb 82 | *.pgc 83 | *.pgd 84 | *.rsp 85 | *.sbr 86 | *.tlb 87 | *.tli 88 | *.tlh 89 | *.tmp 90 | *.tmp_proj 91 | *_wpftmp.csproj 92 | *.log 93 | *.tlog 94 | *.vspscc 95 | *.vssscc 96 | .builds 97 | *.pidb 98 | *.svclog 99 | *.scc 100 | 101 | # Chutzpah Test files 102 | _Chutzpah* 103 | 104 | # Visual C++ cache files 105 | ipch/ 106 | *.aps 107 | *.ncb 108 | *.opendb 109 | *.opensdf 110 | *.sdf 111 | *.cachefile 112 | *.VC.db 113 | *.VC.VC.opendb 114 | 115 | # Visual Studio profiler 116 | *.psess 117 | *.vsp 118 | *.vspx 119 | *.sap 120 | 121 | # Visual Studio Trace Files 122 | *.e2e 123 | 124 | # TFS 2012 Local Workspace 125 | $tf/ 126 | 127 | # Guidance Automation Toolkit 128 | *.gpState 129 | 130 | # ReSharper is a .NET coding add-in 131 | _ReSharper*/ 132 | *.[Rr]e[Ss]harper 133 | *.DotSettings.user 134 | 135 | # TeamCity is a build add-in 136 | _TeamCity* 137 | 138 | # DotCover is a Code Coverage Tool 139 | *.dotCover 140 | 141 | # AxoCover is a Code Coverage Tool 142 | .axoCover/* 143 | !.axoCover/settings.json 144 | 145 | # Coverlet is a free, cross platform Code Coverage Tool 146 | coverage*.json 147 | coverage*.xml 148 | coverage*.info 149 | 150 | # Visual Studio code coverage results 151 | *.coverage 152 | *.coveragexml 153 | 154 | # NCrunch 155 | _NCrunch_* 156 | .*crunch*.local.xml 157 | nCrunchTemp_* 158 | 159 | # MightyMoose 160 | *.mm.* 161 | AutoTest.Net/ 162 | 163 | # Web workbench (sass) 164 | .sass-cache/ 165 | 166 | # Installshield output folder 167 | [Ee]xpress/ 168 | 169 | # DocProject is a documentation generator add-in 170 | DocProject/buildhelp/ 171 | DocProject/Help/*.HxT 172 | DocProject/Help/*.HxC 173 | DocProject/Help/*.hhc 174 | DocProject/Help/*.hhk 175 | DocProject/Help/*.hhp 176 | DocProject/Help/Html2 177 | DocProject/Help/html 178 | 179 | # Click-Once directory 180 | publish/ 181 | 182 | # Publish Web Output 183 | *.[Pp]ublish.xml 184 | *.azurePubxml 185 | # Note: Comment the next line if you want to checkin your web deploy settings, 186 | # but database connection strings (with potential passwords) will be unencrypted 187 | *.pubxml 188 | *.publishproj 189 | 190 | # Microsoft Azure Web App publish settings. Comment the next line if you want to 191 | # checkin your Azure Web App publish settings, but sensitive information contained 192 | # in these scripts will be unencrypted 193 | PublishScripts/ 194 | 195 | # NuGet Packages 196 | *.nupkg 197 | # NuGet Symbol Packages 198 | *.snupkg 199 | # The packages folder can be ignored because of Package Restore 200 | **/[Pp]ackages/* 201 | # except build/, which is used as an MSBuild target. 202 | !**/[Pp]ackages/build/ 203 | # Uncomment if necessary however generally it will be regenerated when needed 204 | #!**/[Pp]ackages/repositories.config 205 | # NuGet v3's project.json files produces more ignorable files 206 | *.nuget.props 207 | *.nuget.targets 208 | 209 | # Microsoft Azure Build Output 210 | csx/ 211 | *.build.csdef 212 | 213 | # Microsoft Azure Emulator 214 | ecf/ 215 | rcf/ 216 | 217 | # Windows Store app package directories and files 218 | AppPackages/ 219 | BundleArtifacts/ 220 | Package.StoreAssociation.xml 221 | _pkginfo.txt 222 | *.appx 223 | *.appxbundle 224 | *.appxupload 225 | 226 | # Visual Studio cache files 227 | # files ending in .cache can be ignored 228 | *.[Cc]ache 229 | # but keep track of directories ending in .cache 230 | !?*.[Cc]ache/ 231 | 232 | # Others 233 | ClientBin/ 234 | ~$* 235 | *~ 236 | *.dbmdl 237 | *.dbproj.schemaview 238 | *.jfm 239 | *.pfx 240 | *.publishsettings 241 | orleans.codegen.cs 242 | 243 | # Including strong name files can present a security risk 244 | # (https://github.com/github/gitignore/pull/2483#issue-259490424) 245 | #*.snk 246 | 247 | # Since there are multiple workflows, uncomment next line to ignore bower_components 248 | # (https://github.com/github/gitignore/pull/1529#issuecomment-104372622) 249 | #bower_components/ 250 | 251 | # RIA/Silverlight projects 252 | Generated_Code/ 253 | 254 | # Backup & report files from converting an old project file 255 | # to a newer Visual Studio version. Backup files are not needed, 256 | # because we have git ;-) 257 | _UpgradeReport_Files/ 258 | Backup*/ 259 | UpgradeLog*.XML 260 | UpgradeLog*.htm 261 | ServiceFabricBackup/ 262 | *.rptproj.bak 263 | 264 | # SQL Server files 265 | *.mdf 266 | *.ldf 267 | *.ndf 268 | 269 | # Business Intelligence projects 270 | *.rdl.data 271 | *.bim.layout 272 | *.bim_*.settings 273 | *.rptproj.rsuser 274 | *- [Bb]ackup.rdl 275 | *- [Bb]ackup ([0-9]).rdl 276 | *- [Bb]ackup ([0-9][0-9]).rdl 277 | 278 | # Microsoft Fakes 279 | FakesAssemblies/ 280 | 281 | # GhostDoc plugin setting file 282 | *.GhostDoc.xml 283 | 284 | # Node.js Tools for Visual Studio 285 | .ntvs_analysis.dat 286 | node_modules/ 287 | 288 | # Visual Studio 6 build log 289 | *.plg 290 | 291 | # Visual Studio 6 workspace options file 292 | *.opt 293 | 294 | # Visual Studio 6 auto-generated workspace file (contains which files were open etc.) 295 | *.vbw 296 | 297 | # Visual Studio 6 auto-generated project file (contains which files were open etc.) 298 | *.vbp 299 | 300 | # Visual Studio 6 workspace and project file (working project files containing files to include in project) 301 | *.dsw 302 | *.dsp 303 | 304 | # Visual Studio 6 technical files 305 | *.ncb 306 | *.aps 307 | 308 | # Visual Studio LightSwitch build output 309 | **/*.HTMLClient/GeneratedArtifacts 310 | **/*.DesktopClient/GeneratedArtifacts 311 | **/*.DesktopClient/ModelManifest.xml 312 | **/*.Server/GeneratedArtifacts 313 | **/*.Server/ModelManifest.xml 314 | _Pvt_Extensions 315 | 316 | # Paket dependency manager 317 | .paket/paket.exe 318 | paket-files/ 319 | 320 | # FAKE - F# Make 321 | .fake/ 322 | 323 | # CodeRush personal settings 324 | .cr/personal 325 | 326 | # Python Tools for Visual Studio (PTVS) 327 | __pycache__/ 328 | *.pyc 329 | 330 | # Cake - Uncomment if you are using it 331 | # tools/** 332 | # !tools/packages.config 333 | 334 | # Tabs Studio 335 | *.tss 336 | 337 | # Telerik's JustMock configuration file 338 | *.jmconfig 339 | 340 | # BizTalk build output 341 | *.btp.cs 342 | *.btm.cs 343 | *.odx.cs 344 | *.xsd.cs 345 | 346 | # OpenCover UI analysis results 347 | OpenCover/ 348 | 349 | # Azure Stream Analytics local run output 350 | ASALocalRun/ 351 | 352 | # MSBuild Binary and Structured Log 353 | *.binlog 354 | 355 | # NVidia Nsight GPU debugger configuration file 356 | *.nvuser 357 | 358 | # MFractors (Xamarin productivity tool) working folder 359 | .mfractor/ 360 | 361 | # Local History for Visual Studio 362 | .localhistory/ 363 | 364 | # Visual Studio History (VSHistory) files 365 | .vshistory/ 366 | 367 | # BeatPulse healthcheck temp database 368 | healthchecksdb 369 | 370 | # Backup folder for Package Reference Convert tool in Visual Studio 2017 371 | MigrationBackup/ 372 | 373 | # Ionide (cross platform F# VS Code tools) working folder 374 | .ionide/ 375 | 376 | # Fody - auto-generated XML schema 377 | FodyWeavers.xsd 378 | 379 | # VS Code files for those working on multiple tools 380 | .vscode/* 381 | !.vscode/settings.json 382 | !.vscode/tasks.json 383 | !.vscode/launch.json 384 | !.vscode/extensions.json 385 | *.code-workspace 386 | 387 | # Local History for Visual Studio Code 388 | .history/ 389 | 390 | # Windows Installer files from build outputs 391 | *.cab 392 | *.msi 393 | *.msix 394 | *.msm 395 | *.msp 396 | 397 | # JetBrains Rider 398 | *.sln.iml 399 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/wwwroot/lottie/BunBun.json: -------------------------------------------------------------------------------- 1 | {"v":"5.5.7","meta":{"g":"LottieFiles AE 0.1.20","a":"","k":"","d":"","tc":""},"fr":60,"ip":0,"op":181,"w":1000,"h":1000,"nm":"Group 6","ddd":0,"assets":[{"id":"comp_0","layers":[{"ddd":0,"ind":1,"ty":4,"nm":"zig zag/Group 6 Outlines 2","parent":2,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[287.528,279.089,0],"ix":2},"a":{"a":0,"k":[201,182,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[-16.836,16.283],[-16.834,16.281],[-16.835,16.281],[-16.837,16.283],[-16.837,16.284],[-16.837,16.285],[-16.837,16.284],[-16.84,16.286],[-16.839,16.286]],"o":[[16.837,-16.283],[16.835,-16.282],[16.835,-16.281],[16.836,-16.284],[16.837,-16.283],[16.838,-16.284],[16.838,-16.283],[16.84,-16.286],[16.839,-16.285],[0,0]],"v":[[-158.483,139.365],[-110.906,121.175],[-91.142,74.236],[-43.569,56.05],[-23.799,9.106],[23.777,-9.085],[43.548,-56.03],[91.126,-74.221],[110.902,-121.17],[158.483,-139.365]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0,0,0,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":16.879,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[200.681,181.562],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":0,"k":0,"ix":1},"e":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":101,"s":[0]},{"t":129,"s":[100]}],"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":0,"op":181,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":4,"nm":"sausage Outlines 2","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.899},"o":{"x":0.333,"y":0},"t":35,"s":[-94.241,1083.395,0],"to":[75.107,-73.726,0],"ti":[-156.414,153.538,0]},{"i":{"x":0,"y":0.533},"o":{"x":0.167,"y":0.668},"t":58,"s":[545.34,447.783,0],"to":[39.458,-38.732,0],"ti":[16.759,-16.662,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.167,"y":0.515},"t":78,"s":[482.032,511.557,0],"to":[-3.788,3.767,0],"ti":[-1.958,1.556,0]},{"t":97,"s":[493.78,502.22,0]}],"ix":2},"a":{"a":0,"k":[283.309,283.309,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[19.23,19.23],[-19.211,19.221],[0,0],[-19.23,-19.231],[19.211,-19.222]],"o":[[-19.231,19.23],[-19.211,-19.221],[0,0],[19.23,-19.231],[19.211,19.22],[0,0]],"v":[[-152.266,221.881],[-221.9,221.881],[-221.9,152.267],[152.267,-221.88],[221.9,-221.88],[221.9,-152.265]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0,0,0,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":16.879,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[0.917999985639,0.352999997606,0.277999997606,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[283.308,283.308],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":181,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":4,"nm":"zig zag/Group 6 Outlines","parent":4,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[287.528,279.089,0],"ix":2},"a":{"a":0,"k":[201,182,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[-16.836,16.283],[-16.834,16.281],[-16.835,16.281],[-16.837,16.283],[-16.837,16.284],[-16.837,16.285],[-16.837,16.284],[-16.84,16.286],[-16.839,16.286]],"o":[[16.837,-16.283],[16.835,-16.282],[16.835,-16.281],[16.836,-16.284],[16.837,-16.283],[16.838,-16.284],[16.838,-16.283],[16.84,-16.286],[16.839,-16.285],[0,0]],"v":[[-158.483,139.365],[-110.906,121.175],[-91.142,74.236],[-43.569,56.05],[-23.799,9.106],[23.777,-9.085],[43.548,-56.03],[91.126,-74.221],[110.902,-121.17],[158.483,-139.365]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0,0,0,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":16.879,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[200.681,181.562],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":181,"st":0,"bm":0},{"ddd":0,"ind":4,"ty":4,"nm":"sausage Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.869,"y":1},"o":{"x":1,"y":0},"t":10,"s":[493.78,502.22,0],"to":[102.647,-100.896,0],"ti":[-102.647,100.896,0]},{"t":35,"s":[1109.663,-103.156,0]}],"ix":2},"a":{"a":0,"k":[283.309,283.309,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[19.23,19.23],[-19.211,19.221],[0,0],[-19.23,-19.231],[19.211,-19.222]],"o":[[-19.231,19.23],[-19.211,-19.221],[0,0],[19.23,-19.231],[19.211,19.22],[0,0]],"v":[[-152.266,221.881],[-221.9,221.881],[-221.9,152.267],[152.267,-221.88],[221.9,-221.88],[221.9,-152.265]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0,0,0,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":16.879,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[0.917999985639,0.352999997606,0.277999997606,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[283.308,283.308],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":181,"st":0,"bm":0}]}],"layers":[{"ddd":0,"ind":1,"ty":0,"nm":"sausage","refId":"comp_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[500,500,0],"ix":2},"a":{"a":0,"k":[500,500,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"hasMask":true,"masksProperties":[{"inv":false,"mode":"s","pt":{"a":0,"k":{"i":[[68,108],[0,0],[0,0],[0,0],[64,49]],"o":[[-15.047,-23.898],[0,0],[0,0],[0,0],[-41.319,-31.635]],"v":[[79,745],[6,788],[-76,1086],[248,1052],[251,917]],"c":true},"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 1"},{"inv":false,"mode":"s","pt":{"a":0,"k":{"i":[[0,0],[-44.823,-30.774],[-16,-22],[0,0],[0,0],[0,0]],"o":[[0,0],[67,46],[12.9,17.737],[0,0],[0,0],[0,0]],"v":[[776,-65],[761,89],[905,228],[990,201],[1149,184],[1192,-52]],"c":true},"ix":1},"o":{"a":0,"k":100,"ix":3},"x":{"a":0,"k":0,"ix":4},"nm":"Mask 2"}],"w":1000,"h":1000,"ip":0,"op":181,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":4,"nm":"bun Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":51,"s":[495.78,504.22,0],"to":[2.833,-2.833,0],"ti":[-0.833,0.833,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":59,"s":[512.78,487.22,0],"to":[0.833,-0.833,0],"ti":[2.833,-2.833,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"t":75,"s":[500.78,499.22,0],"to":[-2.833,2.833,0],"ti":[0.833,-0.833,0]},{"t":85,"s":[495.78,504.22,0]}],"ix":2},"a":{"a":0,"k":[283.309,283.309,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[-19.212,19.23],[0,0],[19.212,19.22],[0,0]],"o":[[0,0],[19.23,19.23],[0,0],[19.212,-19.23],[0,0],[0,0]],"v":[[-217.598,129.445],[-175.805,170.497],[-106.189,170.497],[170.516,-106.172],[170.516,-175.794],[136.283,-209.918]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0,0,0,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":16.879,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[334.692,334.692],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[19.229,-19.231],[0,0],[-19.211,-19.221],[0,0]],"o":[[0,0],[-19.212,-19.231],[0,0],[-19.23,19.231],[0,0],[0,0]],"v":[[239.409,-107.256],[175.804,-170.497],[106.19,-170.497],[-170.498,106.171],[-170.516,175.794],[-116.445,229.598]],"c":false},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0,0,0,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":16.879,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[231.925,231.925],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 2","np":2,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[19.229,-19.231],[0,0],[-19.211,-19.221],[0,0],[-19.211,19.231],[0,0],[19.211,19.22]],"o":[[-19.212,-19.231],[0,0],[-19.23,19.231],[0,0],[19.23,19.231],[0,0],[19.211,-19.231],[0,0]],"v":[[124.421,-221.881],[54.807,-221.881],[-221.881,54.787],[-221.9,124.411],[-124.42,221.88],[-54.807,221.88],[221.9,-54.788],[221.9,-124.411]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.957000014361,0.666999966491,0.255000005984,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[283.309,283.309],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 3","np":2,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":181,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":4,"nm":"bg Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[500,500,0],"ix":2},"a":{"a":0,"k":[485.516,485.516,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-268.005,0],[0,-268.005],[268.005,0],[0,268.005]],"o":[[268.005,0],[0,268.005],[-268.005,0],[0,-268.005]],"v":[[0,-485.266],[485.266,0],[0,485.266],[-485.266,0]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.411999990426,0.885999971278,0.616000007181,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[485.516,485.516],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Group 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":181,"st":0,"bm":0}],"markers":[]} -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Component/LottiePlayerModule.cs: -------------------------------------------------------------------------------- 1 | using Microsoft.AspNetCore.Components; 2 | using Microsoft.JSInterop; 3 | 4 | namespace Blazor.Lottie.Player; 5 | /// 6 | /// Provides functionality to control and manage a Lottie animation player in a Blazor application. 7 | /// 8 | /// 9 | /// This class interacts with a JavaScript module to initialize, play, pause, and stop Lottie animations 10 | /// within a specified HTML element. It also implements asynchronous disposal to clean up resources. 11 | /// WARNING: This class does not load lottie javascript files, you must load those yourself or use the component. 12 | /// 13 | public class LottiePlayerModule : IAsyncDisposable 14 | { 15 | internal readonly IJSRuntime _js; 16 | internal IJSObjectReference? _lottieAnimationRef; 17 | internal readonly ElementReference _elementRef; 18 | internal DotNetObjectReference? _dotNetReference; 19 | internal bool _isDisposing; 20 | 21 | /// 22 | /// Indicates whether the module can execute javascript based on its current state. 23 | /// 24 | internal bool CanExecute => !(_isDisposing || _js is null || _lottieAnimationRef is null); 25 | 26 | /// 27 | /// The constructor for the LottiePlayerModule class. 28 | /// 29 | /// An active IJSRuntime 30 | /// The reference to the HTML element that the Lottie animation will be rendered in. 31 | public LottiePlayerModule(IJSRuntime js, ElementReference elementRef) 32 | { 33 | _dotNetReference = DotNetObjectReference.Create(this); 34 | _js = js; 35 | _elementRef = elementRef; 36 | } 37 | 38 | /// 39 | /// The current time/frame as reported back after EventFrame events. 40 | /// 41 | public double CurrentFrame { get; private set; } = 0.0; 42 | 43 | /// 44 | /// The total number of frames in the animation as returned by AnimationReady 45 | /// 46 | public double TotalFrames { get; private set; } = 0.0; 47 | 48 | /// 49 | /// Initializes the Lottie player with the specified playback options. 50 | /// 51 | /// This method imports the required JavaScript module and invokes the initialization logic for 52 | /// the Lottie player. It also ensures that the instance is not disposing and that the JavaScript runtime is available before 53 | /// loading the module. 54 | /// The playback options to configure the Lottie player. 55 | /// if the initialization is successful; otherwise, . 56 | public async Task InitializeAsync(LottiePlaybackOptions lottiePlaybackOptions) 57 | { 58 | if (_isDisposing || _js is null) return false; 59 | var _module = await _js.InvokeAsync("import", "./_content/Blazor.Lottie.Player/lottiePlayerModule.js"); 60 | _lottieAnimationRef = await _module!.InvokeAsync("initialize", _dotNetReference, _elementRef, lottiePlaybackOptions); 61 | if (lottiePlaybackOptions.AutoPlay) 62 | { 63 | await PlayAsync(); 64 | } 65 | return _lottieAnimationRef != null; 66 | } 67 | 68 | #region Actions 69 | 70 | /// 71 | /// Plays the Lottie animation. 72 | /// 73 | public ValueTask PlayAsync() 74 | { 75 | if (!CanExecute) return ValueTask.CompletedTask; 76 | return _lottieAnimationRef!.InvokeVoidAsync("play"); 77 | } 78 | 79 | /// 80 | /// Pauses the currently playing Lottie animation. 81 | /// 82 | public ValueTask PauseAsync() 83 | { 84 | if (!CanExecute) return ValueTask.CompletedTask; 85 | return _lottieAnimationRef!.InvokeVoidAsync("pause"); 86 | } 87 | 88 | /// 89 | /// Stops the currently playing Lottie animation. 90 | /// 91 | public ValueTask StopAsync() 92 | { 93 | if (!CanExecute) return ValueTask.CompletedTask; 94 | return _lottieAnimationRef!.InvokeVoidAsync("stop"); 95 | } 96 | 97 | /// 98 | /// Moves the animation to the specified frame and starts playback from that point. 99 | /// 100 | /// The frame number to move the animation to. Must be a non-negative value. 101 | /// A boolean value indicating whether to force the animation to move to the specified frame even if it is already 102 | /// playing. to force the action; otherwise, . 103 | public ValueTask GoToAndPlay(double frame, bool force = false) 104 | { 105 | if (!CanExecute) return ValueTask.CompletedTask; 106 | return _lottieAnimationRef!.InvokeVoidAsync("goToAndPlay", frame, force); 107 | } 108 | 109 | /// 110 | /// Moves the animation to the specified frame and stops playback at that point. 111 | /// 112 | /// The frame number to move the animation to. Must be a non-negative value. 113 | /// A boolean value indicating whether to force the animation to move to the specified frame even if it is already 114 | /// playing. to force the action; otherwise, . 115 | public ValueTask GoToAndStop(double frame, bool force = false) 116 | { 117 | if (!CanExecute) return ValueTask.CompletedTask; 118 | return _lottieAnimationRef!.InvokeVoidAsync("goToAndStop", frame, force); 119 | } 120 | 121 | /// 122 | /// Asynchronously sets the speed for the associated animation. 1 is normal speed, 2 is double speed, 0.5 is half speed, etc. 123 | /// 124 | /// The speed value to set. Must be a non-negative number. 125 | public ValueTask SetSpeedAsync(double speed) 126 | { 127 | if (!CanExecute || speed < 0) return ValueTask.CompletedTask; 128 | return _lottieAnimationRef!.InvokeVoidAsync("setSpeed", speed); 129 | } 130 | 131 | /// 132 | /// Asynchronously sets the playback direction for the associated animation. 133 | /// 134 | /// The direction to play the animation. It can be forward or backward. 135 | public ValueTask SetDirectionAsync(LottieAnimationDirection direction) 136 | { 137 | if (!CanExecute) return ValueTask.CompletedTask; 138 | var dir = (int)direction; 139 | return _lottieAnimationRef!.InvokeVoidAsync("setDirection", dir); 140 | } 141 | 142 | /// 143 | /// Executes javascript directly from the Lottie animation reference. So you can call any method that is available on the Lottie animation object. 144 | /// 145 | /// 146 | /// 147 | /// 148 | public ValueTask ExecuteActionAsync(string action, params object?[]? args) 149 | { 150 | if (!CanExecute) return ValueTask.CompletedTask; 151 | return _lottieAnimationRef!.InvokeVoidAsync(action, args); 152 | } 153 | 154 | #endregion 155 | 156 | #region Events 157 | 158 | /// 159 | /// Triggers when the Lottie animation is ready to be played and loaded by the DOM. 160 | /// 161 | public event EventHandler? OnAnimationReady; 162 | 163 | /// 164 | /// Triggers when the Lottie animation has fully loaded in the DOM. 165 | /// 166 | public event EventHandler? OnDOMLoaded; 167 | 168 | /// 169 | /// Triggers when the Lottie animation enters a new frame. 170 | /// 171 | public event EventHandler? OnEnterFrame; 172 | 173 | /// 174 | /// Triggers when the Lottie animation completes playing. 175 | /// 176 | /// 177 | /// If an animation is set to loop indefinitely, this event will not be triggered. 178 | /// 179 | public event EventHandler? OnComplete; 180 | 181 | /// 182 | /// Triggers when the Lottie animation completes a loop. 183 | /// 184 | public event EventHandler? OnLoopComplete; 185 | 186 | /// 187 | /// Invokes the event when the animation is ready. (DOMLoaded) 188 | /// 189 | [JSInvokable] 190 | public Task AnimationReadyEvent(LottiePlayerLoadedEventArgs args) 191 | { 192 | if (!CanExecute) return Task.CompletedTask; 193 | TotalFrames = args.TotalFrames; 194 | OnAnimationReady?.Invoke(this, args); 195 | return Task.CompletedTask; 196 | } 197 | 198 | /// 199 | /// Invokes the event when the DOM is fully loaded with the Lottie animation. 200 | /// 201 | /// 202 | [JSInvokable] 203 | public Task DOMLoadedEvent(LottiePlayerLoadedEventArgs args) 204 | { 205 | if (!CanExecute) return Task.CompletedTask; 206 | 207 | OnDOMLoaded?.Invoke(this, args); 208 | return Task.CompletedTask; 209 | } 210 | 211 | /// 212 | /// Invokes the event when the animation completes. 213 | /// 214 | /// 215 | /// This event is triggered when the animation has finished playing all frames and loops, if applicable. If it's set to loop 216 | /// indefinitely, this event will never be triggered. 217 | /// 218 | [JSInvokable] 219 | public Task CompleteEvent() 220 | { 221 | if (!CanExecute) return Task.CompletedTask; 222 | 223 | OnComplete?.Invoke(this, true); 224 | return Task.CompletedTask; 225 | } 226 | 227 | /// 228 | /// Invokes the event when a loop completes. 229 | /// 230 | [JSInvokable] 231 | public Task LoopCompleteEvent() 232 | { 233 | if (!CanExecute) return Task.CompletedTask; 234 | 235 | OnLoopComplete?.Invoke(this, true); 236 | return Task.CompletedTask; 237 | } 238 | 239 | /// 240 | /// Invokes the event with the specified arguments. 241 | /// 242 | [JSInvokable] 243 | public Task EnterFrameEvent(LottiePlayerEventFrameArgs args) 244 | { 245 | if (!CanExecute) return Task.CompletedTask; 246 | CurrentFrame = args.CurrentTime; 247 | OnEnterFrame?.Invoke(this, args); 248 | return Task.CompletedTask; 249 | } 250 | 251 | #endregion 252 | 253 | /// 254 | /// Disposes the Lottie player module and cleans up resources. 255 | /// 256 | public async ValueTask DisposeAsync() 257 | { 258 | _isDisposing = true; 259 | if (_lottieAnimationRef is not null) 260 | { 261 | try 262 | { 263 | await _lottieAnimationRef.InvokeVoidAsync("destroy"); 264 | } 265 | catch (JSException) 266 | { 267 | // Ignore JS exceptions during dispose, as the module may already be disposed. 268 | } 269 | await _lottieAnimationRef.DisposeAsync(); 270 | _lottieAnimationRef = null; 271 | } 272 | if (_dotNetReference is not null) 273 | { 274 | _dotNetReference.Dispose(); 275 | _dotNetReference = null; 276 | } 277 | GC.SuppressFinalize(this); 278 | } 279 | } 280 | -------------------------------------------------------------------------------- /tests/Blazor.Lottie.Player.UnitTests/LottieTests.cs: -------------------------------------------------------------------------------- 1 | using System.Reflection; 2 | using AwesomeAssertions; 3 | using Bunit; 4 | using Microsoft.JSInterop; 5 | using Moq; 6 | 7 | namespace Blazor.Lottie.Player.UnitTests 8 | { 9 | [TestFixture] 10 | public class LottieTests : BunitTest 11 | { 12 | private const string LottieSrc = "https://raw.githubusercontent.com/MudXtra/LottiePlayer/refs/heads/main/src/Blazor.Lottie.Player.Docs.WASM/wwwroot/lottie/newAnimation.json"; 13 | 14 | [SetUp] 15 | public override void Setup() 16 | { 17 | base.Setup(); 18 | 19 | // Setup the import call to return a mock module 20 | var moduleMock = Context.JSInterop.SetupModule("./_content/Blazor.Lottie.Player/loadLottieWeb.js"); 21 | // Setup the initialize call to return true 22 | moduleMock.Setup("initialize", _ => true).SetResult(true); 23 | 24 | var lottieModuleMock = Context.JSInterop.SetupModule("./_content/Blazor.Lottie.Player/lottiePlayerModule.js"); 25 | var animationModuleMock = new Mock(); 26 | lottieModuleMock.SetupVoid("initialize"); 27 | 28 | lottieModuleMock.Setup("play", _ => true).SetResult(true); 29 | lottieModuleMock.Setup("pause", _ => true).SetResult(true); 30 | lottieModuleMock.Setup("stop", _ => true).SetResult(true); 31 | lottieModuleMock.Setup("destroy", _ => true).SetResult(true); 32 | lottieModuleMock.Setup("setSpeed", _ => true).SetResult(true); 33 | lottieModuleMock.Setup("setDirection", _ => true).SetResult(true); 34 | } 35 | 36 | [Test] 37 | public async Task LottieComponentRendersCorrectly() 38 | { 39 | // Arrange 40 | var comp = Context.RenderComponent(parameters => parameters 41 | .Add(p => p.Src, LottieSrc) 42 | .Add(p => p.Class, "test-class") 43 | .Add(p => p.Style, "width: 100%; height: 100%;") 44 | ); 45 | // Act 46 | var element = comp.Find($"#{comp.Instance.ElementId}"); 47 | element.Should().NotBeNull(); 48 | 49 | // Assert Defaults 50 | comp.Instance.AutoPlay.Should().BeTrue(); 51 | comp.Instance.Loop.Should().BeTrue(); 52 | comp.Instance.LoopCount.Should().Be(0); 53 | comp.Instance.AnimationType.Should().Be(LottieAnimationType.Svg); 54 | comp.Instance.AnimationSpeed.Should().Be(1.0); 55 | comp.Instance.AnimationDirection.Should().Be(LottieAnimationDirection.Forward); 56 | var options = comp.Instance.AnimationOptions; 57 | options.Should().NotBeNull(); 58 | options.LottieSourceJs.Should().Be("https://cdnjs.cloudflare.com/ajax/libs/lottie-web/5.13.0/lottie.min.js"); 59 | options.AnimationQuality.Should().Be(LottieAnimationQuality.High); 60 | options.SmoothFrameInterpolation.Should().BeTrue(); 61 | 62 | // get and invoke private void HandleAnimationReady(object? sender, LottiePlayerLoadedEventArgs args) 63 | var method = typeof(LottiePlayer).GetMethod("HandleAnimationReady", BindingFlags.NonPublic | BindingFlags.Instance); 64 | method.Should().NotBeNull(); 65 | // Invoke the method with a mock LottiePlayerLoadedEventArgs 66 | var args = new LottiePlayerLoadedEventArgs 67 | { 68 | ElementId = comp.Instance.ElementId, 69 | CurrentFrame = 0.0, 70 | TotalFrames = 100.0, 71 | }; 72 | await comp.InvokeAsync(() => method.Invoke(comp.Instance, [this, args])); 73 | 74 | comp.Instance.IsAnimationLoaded.Should().BeTrue(); 75 | comp.Instance.IsAnimationPaused.Should().Be(!comp.Instance.AutoPlay); 76 | comp.Instance.CurrentAnimationFrame.Should().Be(0.0); 77 | } 78 | 79 | [Test] 80 | public void LottiePlayer_RendersUserAttributes() 81 | { 82 | var comp = Context.RenderComponent(parameters => parameters 83 | .Add(p => p.Src, "https://example.com/lottie.json") 84 | ); 85 | var element = comp.Find($"#{comp.Instance.ElementId}"); 86 | 87 | // Check default attributes 88 | element.HasAttribute("data-test").Should().BeFalse(); 89 | element.GetAttribute("role").Should().Be("animation"); 90 | element.GetAttribute("aria-label").Should().Be("Lottie Animation"); 91 | 92 | comp.SetParametersAndRender(parameters => parameters 93 | .Add(p => p.UserAttributes, new Dictionary 94 | { 95 | { "data-test", "abc" }, 96 | { "aria-label", "lottie" } 97 | }) 98 | ); 99 | 100 | element = comp.Find($"#{comp.Instance.ElementId}"); 101 | 102 | element.HasAttribute("data-test").Should().BeTrue(); 103 | element.GetAttribute("data-test").Should().Be("abc"); 104 | element.GetAttribute("aria-label").Should().Be("lottie"); 105 | element.GetAttribute("role").Should().Be("animation"); 106 | } 107 | 108 | [Test] 109 | public void LottiePlayer_ClassnameAndStylename_NullOrWhitespace() 110 | { 111 | var comp = Context.RenderComponent(parameters => parameters 112 | .Add(p => p.Src, "https://example.com/lottie.json") 113 | .Add(p => p.Class, null) 114 | .Add(p => p.Style, " ") 115 | ); 116 | var element = comp.Find($"#{comp.Instance.ElementId}"); 117 | element.ClassList.Should().Contain("blazor-lottie-player"); 118 | element.GetAttribute("style").Should().BeNullOrWhiteSpace(); 119 | } 120 | 121 | [Test] 122 | public void LottiePlayer_PublicMethods_ThrowIfModuleNull() 123 | { 124 | var comp = Context.RenderComponent(parameters => parameters 125 | .Add(p => p.Src, "https://example.com/lottie.json") 126 | ); 127 | // Simulate module disposal 128 | comp.Instance.LottiePlayerModule.Should().NotBeNull(); 129 | comp.InvokeAsync(() => comp.Instance.DisposeAsync()); 130 | comp.Instance.LottiePlayerModule.Should().BeNull(); 131 | 132 | Assert.ThrowsAsync(async () => await comp.Instance.PlayAnimationAsync()); 133 | Assert.ThrowsAsync(async () => await comp.Instance.PauseAnimationAsync()); 134 | Assert.ThrowsAsync(async () => await comp.Instance.StopAnimationAsync()); 135 | Assert.ThrowsAsync(async () => await comp.Instance.SetSpeedAsync(1.0)); 136 | Assert.ThrowsAsync(async () => await comp.Instance.SetDirectionAsync(LottieAnimationDirection.Forward)); 137 | } 138 | 139 | [Test] 140 | public void LottiePlayer_ThrowsIfJsModuleFailsToLoad() 141 | { 142 | var moduleMock = Context.JSInterop.SetupModule("./_content/Blazor.Lottie.Player/loadLottieWeb.js"); 143 | moduleMock.Setup("initialize", _ => false); 144 | 145 | var ex = Assert.Throws(() => 146 | Context.RenderComponent(parameters => parameters 147 | .Add(p => p.Src, "https://example.com/lottie.json") 148 | ) 149 | ); 150 | ex.Message.Should().Contain("Failed to initialize Lottie Web Player Module"); 151 | } 152 | 153 | 154 | 155 | [Test] 156 | public void LottiePlayer_InitShouldReinitReasonably() 157 | { 158 | var comp = Context.RenderComponent(parameters => parameters 159 | .Add(p => p.Src, LottieSrc) 160 | ); 161 | 162 | var field = typeof(LottiePlayer).GetField("_initCount", BindingFlags.NonPublic | BindingFlags.Instance); 163 | field.Should().NotBeNull(); 164 | var initCount = (int)field.GetValue(comp.Instance)!; 165 | initCount.Should().Be(1); 166 | 167 | // Changing these parameters should not reinitialize 168 | comp.SetParametersAndRender(parameters => parameters 169 | .Add(p => p.Class, "test-class") 170 | .Add(p => p.Style, "width: 100%; height: 100%;") 171 | .Add(p => p.UserAttributes, new Dictionary 172 | { 173 | { "data-test", "test-value" } 174 | }) 175 | ); 176 | initCount = (int)field.GetValue(comp.Instance)!; 177 | initCount.Should().Be(1); 178 | 179 | // Change any of these parameters should reinitialize but only once per parameter submission 180 | comp.SetParametersAndRender(parameters => parameters 181 | .Add(p => p.Src, "https://assets2.lottiefiles.com/packages/lf20_8j3q1k.json") 182 | .Add(p => p.AutoPlay, false) 183 | .Add(p => p.Loop, false) 184 | .Add(p => p.LoopCount, 5) 185 | .Add(p => p.AnimationType, LottieAnimationType.Canvas) 186 | .Add(p => p.AnimationSpeed, 0.5) 187 | .Add(p => p.AnimationDirection, LottieAnimationDirection.Reverse) 188 | ); 189 | initCount = (int)field.GetValue(comp.Instance)!; 190 | initCount.Should().Be(2); 191 | 192 | // Change a single parameter on the list should reinitialize 193 | comp.SetParametersAndRender(parameters => parameters 194 | .Add(p => p.AnimationType, LottieAnimationType.Html) 195 | ); 196 | initCount = (int)field.GetValue(comp.Instance)!; 197 | initCount.Should().Be(3); 198 | 199 | var options = new LottieAnimationOptions 200 | { 201 | AnimationQuality = LottieAnimationQuality.Medium 202 | }; 203 | comp.Instance.AnimationOptions.Should().NotBe(options.AnimationQuality); 204 | 205 | // Change a options class should reinitialize 206 | comp.SetParametersAndRender(parameters => parameters 207 | .Add(p => p.AnimationOptions, options) 208 | ); 209 | initCount = (int)field.GetValue(comp.Instance)!; 210 | initCount.Should().Be(4); 211 | } 212 | 213 | [Test] 214 | public async Task LottiePlayer_PublicMethods() 215 | { 216 | var comp = Context.RenderComponent(parameters => parameters 217 | .Add(p => p.Src, LottieSrc) 218 | ); 219 | // Check public methods 220 | comp.Instance.AutoPlay.Should().BeTrue(); 221 | comp.Instance.IsAnimationLoaded.Should().BeTrue(); 222 | comp.Instance.IsAnimationPaused.Should().BeFalse(); 223 | 224 | await comp.InvokeAsync(async () => await comp.Instance.PauseAnimationAsync()); 225 | comp.Instance.IsAnimationPaused.Should().BeTrue(); 226 | 227 | await comp.InvokeAsync(async () => await comp.Instance.PlayAnimationAsync()); 228 | comp.Instance.IsAnimationPaused.Should().BeFalse(); 229 | 230 | await comp.InvokeAsync(async () => await comp.Instance.SetSpeedAsync(2.0)); 231 | 232 | await comp.InvokeAsync(async () => await comp.Instance.SetDirectionAsync(LottieAnimationDirection.Reverse)); 233 | 234 | await comp.InvokeAsync(async () => await comp.Instance.StopAnimationAsync()); 235 | comp.Instance.IsAnimationPaused.Should().BeFalse(); 236 | comp.Instance.IsAnimationStopped.Should().BeTrue(); 237 | } 238 | 239 | [Test] 240 | public void LottiePlayer_Events() 241 | { 242 | bool handledom = false, 243 | handleenterframe = false, 244 | handlecomplete = false, 245 | handleloopcomplete = false, 246 | handleanimationready = false; 247 | 248 | var comp = Context.RenderComponent(parameters => parameters 249 | .Add(p => p.Src, LottieSrc) 250 | .Add(p => p.DOMLoaded, (() => handledom = true)) 251 | .Add(p => p.AnimationReady, () => handleenterframe = true) 252 | .Add(p => p.AnimationCompleted, (isLooping) => handlecomplete = true) 253 | .Add(p => p.AnimationLoopCompleted, (isLooping) => handleloopcomplete = true) 254 | .Add(p => p.CurrentFrameChanged, (args) => handleanimationready = true) 255 | ); 256 | // invoke the methods that invoke the events 257 | var domloadedMethod = typeof(LottiePlayer).GetMethod("HandleDOMLoaded", BindingFlags.NonPublic | BindingFlags.Instance); 258 | comp.InvokeAsync(() => domloadedMethod!.Invoke(comp.Instance, [this, new LottiePlayerLoadedEventArgs()])); 259 | var animationReadyMethod = typeof(LottiePlayer).GetMethod("HandleAnimationReady", BindingFlags.NonPublic | BindingFlags.Instance); 260 | comp.InvokeAsync(() => animationReadyMethod!.Invoke(comp.Instance, [this, new LottiePlayerLoadedEventArgs()])); 261 | var animationCompletedMethod = typeof(LottiePlayer).GetMethod("HandleAnimationCompleted", BindingFlags.NonPublic | BindingFlags.Instance); 262 | comp.InvokeAsync(() => animationCompletedMethod!.Invoke(comp.Instance, [this, true])); 263 | var loopCompleteMethod = typeof(LottiePlayer).GetMethod("HandleAnimationLoopCompleted", BindingFlags.NonPublic | BindingFlags.Instance); 264 | comp.InvokeAsync(() => loopCompleteMethod!.Invoke(comp.Instance, [this, true])); 265 | var currentFrameChangedMethod = typeof(LottiePlayer).GetMethod("HandleCurrentFrameChanged", BindingFlags.NonPublic | BindingFlags.Instance); 266 | comp.InvokeAsync(() => currentFrameChangedMethod!.Invoke(comp.Instance, [this, new LottiePlayerEventFrameArgs()])); 267 | 268 | // Check event invocations 269 | handledom.Should().BeTrue(); 270 | handleenterframe.Should().BeTrue(); 271 | handlecomplete.Should().BeTrue(); 272 | handleloopcomplete.Should().BeTrue(); 273 | handleanimationready.Should().BeTrue(); 274 | } 275 | 276 | #pragma warning disable CS8619 277 | private static IEnumerable CurrentFrameChangeFuncCases() 278 | { 279 | yield return new object[] { (Func)(frame => frame % 10 == 0), 10 }; 280 | yield return new object?[] { null, 5 }; 281 | } 282 | #pragma warning restore CS8619 283 | 284 | [Test, TestCaseSource(nameof(CurrentFrameChangeFuncCases))] 285 | public void Lottie_CurrentFrameChanged(object? funcObj, int maxFrames) 286 | { 287 | var currentFrameChangeFunc = funcObj as Func; 288 | var frameChangedCount = 0; 289 | 290 | var comp = Context.RenderComponent(parameters => parameters 291 | .Add(p => p.Src, "https://assets2.lottiefiles.com/packages/lf20_8j3q1k.json") 292 | .Add(p => p.CurrentFrameChangeFunc, currentFrameChangeFunc) 293 | .Add(p => p.CurrentFrameChanged, (Action)(args => 294 | { 295 | frameChangedCount++; 296 | })) 297 | ); 298 | 299 | if (currentFrameChangeFunc != null) 300 | { 301 | for (int frame = 0; frame < maxFrames; frame++) 302 | { 303 | if (currentFrameChangeFunc(frame)) 304 | { 305 | // Your logic here 306 | } 307 | } 308 | } 309 | } 310 | 311 | [Test] 312 | public void LottiePlayer_CurrentFrameChangeFunc_False_DoesNotInvokeEvent() 313 | { 314 | bool eventInvoked = false; 315 | var comp = Context.RenderComponent(parameters => parameters 316 | .Add(p => p.Src, "https://example.com/lottie.json") 317 | .Add(p => p.CurrentFrameChangeFunc, (Func)(_ => false)) 318 | .Add(p => p.CurrentFrameChanged, (Action)(_ => eventInvoked = true)) 319 | ); 320 | // Use reflection to invoke the private handler 321 | var method = typeof(LottiePlayer).GetMethod("HandleCurrentFrameChanged", BindingFlags.NonPublic | BindingFlags.Instance); 322 | method!.Invoke(comp.Instance, [null, new LottiePlayerEventFrameArgs { CurrentTime = 42.0 }]); 323 | eventInvoked.Should().BeFalse(); 324 | } 325 | 326 | [Test] 327 | public async Task LottiePlayer_DisposeAsync_Idempotent() 328 | { 329 | var comp = Context.RenderComponent(parameters => parameters 330 | .Add(p => p.Src, "https://example.com/lottie.json") 331 | ); 332 | await comp.Instance.DisposeAsync(); 333 | // Should not throw or double-dispose 334 | await comp.Instance.DisposeAsync(); 335 | } 336 | 337 | [Test] 338 | public async Task LottiePlayer_InitCount_AfterDisposeAndReinit() 339 | { 340 | var comp = Context.RenderComponent(parameters => parameters 341 | .Add(p => p.Src, "https://example.com/lottie.json") 342 | ); 343 | var field = typeof(LottiePlayer).GetField("_initCount", BindingFlags.NonPublic | BindingFlags.Instance); 344 | int initCount = (int)field!.GetValue(comp.Instance)!; 345 | await comp.Instance.DisposeAsync(); 346 | // Re-initialize by changing a key parameter 347 | comp.SetParametersAndRender(p => p.Add(x => x.Src, "https://example.com/other.json")); 348 | int newInitCount = (int)field.GetValue(comp.Instance)!; 349 | newInitCount.Should().Be(initCount + 1); 350 | } 351 | } 352 | } 353 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/Component/LottiePlayer.razor.cs: -------------------------------------------------------------------------------- 1 | using Blazor.Lottie.Player.Extensions; 2 | using Microsoft.AspNetCore.Components; 3 | using Microsoft.JSInterop; 4 | 5 | namespace Blazor.Lottie.Player; 6 | /// 7 | /// A Blazor component for rendering and controlling Lottie animations using BodyMovin. 8 | /// 9 | /// The component provides a flexible way to integrate Lottie animations into 10 | /// Blazor applications. It supports various customization options, including animation source, playback settings, and 11 | /// event callbacks for animation lifecycle events. 12 | public partial class LottiePlayer : ComponentBase, IAsyncDisposable 13 | { 14 | #region Private Variables 15 | 16 | private ElementReference ElementRef { get; set; } = default!; 17 | /// 18 | /// Represents the unique identifier for a Lottie element's surrounding div. 19 | /// 20 | public readonly string ElementId = Identifier.Create("lottie-"); 21 | private string? _failMessage = null; 22 | private bool _lottieLoaded = false; 23 | /// 24 | /// The module used to control Lottie Player functionality. 25 | /// 26 | public LottiePlayerModule? LottiePlayerModule { get; private set; } 27 | private int _initCount = 0; 28 | 29 | /// 30 | /// The class list for the surrounding div, which includes the base class and the Blazor Lottie Player class. 31 | /// 32 | protected string Classname 33 | => string.IsNullOrWhiteSpace(Class) 34 | ? "blazor-lottie-player" 35 | : $"blazor-lottie-player {Class}"; 36 | 37 | /// 38 | /// The style string for the surrounding div, which includes the base style and any user-defined styles. 39 | /// 40 | protected string? Stylename 41 | => string.IsNullOrWhiteSpace(Style) ? null : Style; 42 | 43 | 44 | /// 45 | /// Returns the merged user attributes with sensible defaults, allowing user overrides. 46 | /// 47 | protected IReadOnlyDictionary MergedUserAttributes 48 | { 49 | get 50 | { 51 | var dict = UserAttributes != null 52 | ? new Dictionary(UserAttributes) 53 | : []; 54 | 55 | dict.TryAdd("aria-label", "Lottie Animation"); 56 | dict.TryAdd("role", "animation"); 57 | return dict; 58 | } 59 | } 60 | 61 | #endregion 62 | 63 | #region Injected Services 64 | 65 | [Inject] 66 | private IJSRuntime JSRuntime { get; set; } = default!; 67 | 68 | #endregion 69 | 70 | #region Parameters 71 | 72 | /// 73 | /// The CSS class name(s) to apply to the container. 74 | /// 75 | [Parameter] 76 | public string? Class { get; set; } 77 | 78 | /// 79 | /// The inline CSS styles to apply to the component. 80 | /// 81 | [Parameter] 82 | public string? Style { get; set; } 83 | 84 | /// 85 | /// Sets a collection of user-defined HTML attributes represented as key-value pairs. 86 | /// 87 | /// 88 | /// This property is typically used to provide additional HTML attributes during 89 | /// rendering such as ARIA accessibility tags, data attributes, or any other custom 90 | /// HTML attributes that you want to apply to the component. 91 | /// 92 | [Parameter(CaptureUnmatchedValues = true)] 93 | public Dictionary? UserAttributes { get; set; } 94 | 95 | /// 96 | /// Gets or sets the source or relative URL for the component's content. 97 | /// 98 | /// 99 | /// *Required* e.g.
100 | /// Src="https://mudxtra.github.io/LottiePlayer/newAnimation.json"
101 | /// Src="./wwwroot/lottie/newAnimation.json" 102 | ///
103 | [Parameter, EditorRequired] 104 | public string Src { get; set; } = default!; 105 | 106 | /// 107 | /// A value indicating whether the media should automatically start playing when loaded. If set to 108 | /// false, the media will not start playing until AnimationPaused is set to false. 109 | /// 110 | [Parameter] 111 | public bool AutoPlay { get; set; } = true; 112 | 113 | /// 114 | /// Gets or sets whether the animation should loop. 115 | /// 116 | [Parameter] 117 | public bool Loop { get; set; } = true; 118 | 119 | /// 120 | /// Gets or sets the number of times a loop should occur. Requires to be true. 121 | /// 122 | /// 123 | /// Default is 0 (infinite loop). 124 | /// 125 | [Parameter] 126 | public int LoopCount { get; set; } = 0; 127 | 128 | /// 129 | /// Gets or sets the type of animation to be used for rendering the Lottie animation. 130 | /// 131 | /// 132 | /// Defaults to . 133 | /// 134 | [Parameter] 135 | public LottieAnimationType AnimationType { get; set; } = LottieAnimationType.Svg; 136 | 137 | /// 138 | /// Gets or sets the direction in which the Lottie animation plays. 139 | /// 140 | /// 141 | /// Defaults to .
142 | /// Changing this property after initialization will not change the playback direction of the animation, use 143 | ///
144 | [Parameter] 145 | public LottieAnimationDirection AnimationDirection { get; set; } = LottieAnimationDirection.Forward; 146 | 147 | /// 148 | /// Gets or sets the speed of the animation. 149 | /// 150 | /// 151 | /// Defaults to 1.0 (normal speed).
152 | /// Changing this property after initialization will not change the speed of the animation, use 153 | ///
154 | [Parameter] 155 | public double AnimationSpeed { get; set; } = 1.0; 156 | 157 | /// 158 | /// Called when the current frame changes, with custom filtering logic 159 | /// 160 | /// 161 | /// The function receives the current frame number and should return true if the event should be raised. 162 | /// This allows for custom throttling logic (e.g., only every 10th frame, only on specific frames, etc.) 163 | ///
Warning: Frame updates could happen as frequently as 30-60 times per second. 164 | ///
Defaults to null. is only raised if something is attached to the handler. 165 | ///
Example: frame => frame % 10 == 0 will raise the event every 10th frame. 166 | ///
167 | [Parameter] public Func? CurrentFrameChangeFunc { get; set; } 168 | 169 | /// 170 | /// Called when the current frame changes (only when returns true) 171 | /// 172 | [Parameter] public EventCallback CurrentFrameChanged { get; set; } 173 | 174 | /// 175 | /// Called when the Lottie player is initialized and the DOM is ready. 176 | /// 177 | [Parameter] 178 | public EventCallback DOMLoaded { get; set; } 179 | 180 | /// 181 | /// Called when the animation is fully loaded and ready for playback. 182 | /// 183 | [Parameter] 184 | public EventCallback AnimationReady { get; set; } 185 | 186 | /// 187 | /// Called when the animation completes. 188 | /// 189 | [Parameter] 190 | public EventCallback AnimationCompleted { get; set; } 191 | 192 | /// 193 | /// Called when an animation loop completes. 194 | /// 195 | [Parameter] 196 | public EventCallback AnimationLoopCompleted { get; set; } 197 | 198 | /// 199 | /// Additional Less Used Animation Options. 200 | /// 201 | /// Refer to for defaults. 202 | [Parameter] 203 | public LottieAnimationOptions AnimationOptions { get; set; } = new(); 204 | 205 | #endregion 206 | 207 | #region Component Public Properties 208 | 209 | /// 210 | /// The total number of frames in the animation. This is set when the animation is loaded and ready for playback. 211 | /// 212 | public double TotalAnimationFrames => LottiePlayerModule?.TotalFrames ?? 0.0; 213 | 214 | /// 215 | /// Gets the current animation frame as a double-precision value. This is updated during playback by the EventCallback of CurrentFrameChanged. 216 | /// 217 | public double CurrentAnimationFrame => LottiePlayerModule?.CurrentFrame ?? 0.0; 218 | 219 | /// 220 | /// Gets a value indicating whether the animation has been loaded and is ready for playback. 221 | /// 222 | public bool IsAnimationLoaded { get; private set; } = false; 223 | 224 | /// 225 | /// Gets a value indicating whether the animation is paused. 226 | /// 227 | public bool IsAnimationPaused { get; private set; } = false; 228 | 229 | /// 230 | /// Gets a value indicating whether the animation is stopped. 231 | /// 232 | public bool IsAnimationStopped { get; private set; } = true; 233 | #endregion 234 | 235 | #region Public Methods 236 | 237 | /// 238 | /// If the animation is not already playing, this method will start playing the animation. 239 | /// 240 | /// Should not be called before OnAfterRenderAsync. 241 | /// if the animation was successfully started; otherwise, . 242 | /// 243 | public async ValueTask PlayAnimationAsync() 244 | { 245 | if (LottiePlayerModule == null) 246 | { 247 | throw new InvalidOperationException("Lottie Player Module failed."); 248 | } 249 | 250 | if (IsAnimationStopped) 251 | { 252 | // If the animation is stopped, we need to reset the frame to 0 before playing 253 | await LottiePlayerModule.GoToAndPlay(0.0, true); 254 | IsAnimationStopped = false; 255 | } 256 | 257 | IsAnimationPaused = false; 258 | await LottiePlayerModule.PlayAsync(); 259 | } 260 | 261 | /// 262 | /// Pauses the currently playing animation in the Lottie player. 263 | /// 264 | /// Should not be called before OnAfterRenderAsync. 265 | /// if the animation was successfully paused; otherwise, . 266 | /// 267 | public async ValueTask PauseAnimationAsync() 268 | { 269 | if (LottiePlayerModule == null) 270 | { 271 | throw new InvalidOperationException("Lottie Player Module failed."); 272 | } 273 | if (IsAnimationStopped) 274 | { 275 | await LottiePlayerModule.GoToAndStop(0.0, true); 276 | IsAnimationStopped = false; 277 | } 278 | IsAnimationPaused = true; 279 | await LottiePlayerModule.PauseAsync(); 280 | } 281 | 282 | /// 283 | /// Stops the currently playing animation asynchronously. 284 | /// 285 | /// This method halts the animation playback if an animation is currently running. The method 286 | /// returns a boolean indicating whether the operation was successful. 287 | /// if the animation was successfully stopped; otherwise, . 288 | /// Thrown if the Lottie Player Module is not initialized. 289 | public ValueTask StopAnimationAsync() 290 | { 291 | if (LottiePlayerModule == null) 292 | { 293 | throw new InvalidOperationException("Lottie Player Module failed."); 294 | } 295 | IsAnimationPaused = false; 296 | IsAnimationStopped = true; 297 | return LottiePlayerModule.StopAsync(); 298 | } 299 | 300 | /// 301 | /// Asynchronously sets the playback speed for the Lottie animation. 302 | /// 303 | /// The desired playback speed. Must be a positive value, where 1.0 represents normal speed. 304 | /// Thrown if the Lottie Player Module is not initialized. 305 | public ValueTask SetSpeedAsync(double speed) 306 | { 307 | if (LottiePlayerModule == null) 308 | { 309 | throw new InvalidOperationException("Lottie Player Module failed."); 310 | } 311 | return LottiePlayerModule.SetSpeedAsync(speed); 312 | } 313 | 314 | /// 315 | /// Sets the playback direction of the Lottie animation asynchronously. 316 | /// 317 | /// The desired playback direction of the animation. Must be a valid value. 318 | /// Thrown if the Lottie Player Module is not initialized. 319 | public ValueTask SetDirectionAsync(LottieAnimationDirection direction) 320 | { 321 | if (LottiePlayerModule == null) 322 | { 323 | throw new InvalidOperationException("Lottie Player Module failed."); 324 | } 325 | return LottiePlayerModule.SetDirectionAsync(direction); 326 | } 327 | 328 | #endregion 329 | 330 | #region Events 331 | 332 | private void HandleDOMLoaded(object? sender, LottiePlayerLoadedEventArgs args) 333 | { 334 | IsAnimationLoaded = true; 335 | DOMLoaded.InvokeAsync(args); 336 | StateHasChanged(); 337 | } 338 | 339 | private void HandleAnimationReady(object? sender, LottiePlayerLoadedEventArgs args) 340 | { 341 | IsAnimationLoaded = true; 342 | AnimationReady.InvokeAsync(args); 343 | StateHasChanged(); 344 | } 345 | 346 | private void HandleAnimationCompleted(object? sender, bool completed) 347 | { 348 | AnimationCompleted.InvokeAsync(); 349 | } 350 | 351 | private void HandleAnimationLoopCompleted(object? sender, bool completed) 352 | { 353 | AnimationLoopCompleted.InvokeAsync(); 354 | } 355 | 356 | private void HandleCurrentFrameChanged(object? sender, LottiePlayerEventFrameArgs args) 357 | { 358 | if (CurrentFrameChangeFunc == null || CurrentFrameChangeFunc.Invoke(args.CurrentTime)) 359 | { 360 | CurrentFrameChanged.InvokeAsync(args); 361 | } 362 | } 363 | 364 | #endregion 365 | 366 | /// 367 | /// Disposes the LottiePlayer Module if it exists, cleaning up resources and references. Then re-initializes it with 368 | /// any updated options. 369 | /// 370 | /// 371 | private async Task InitializeLottieModule() 372 | { 373 | // dispose the existing module if it exists 374 | if (LottiePlayerModule != null && _initCount > 0) 375 | { 376 | // cancel event handlers to prevent memory leaks 377 | EventSubscription(false); 378 | 379 | await LottiePlayerModule.DisposeAsync(); 380 | LottiePlayerModule = null; 381 | IsAnimationLoaded = false; 382 | IsAnimationPaused = false; 383 | } 384 | // initialize the new module with the current parameters 385 | LottiePlayerModule = new LottiePlayerModule(JSRuntime, ElementRef); 386 | var lottiePlaybackOptions = new LottiePlaybackOptions 387 | { 388 | AutoPlay = AutoPlay, 389 | Path = Src, 390 | Renderer = AnimationType.ToDescription(), 391 | Loop = Loop ? (object)(LoopCount > 0 ? LoopCount : true) : false, 392 | Direction = (int)AnimationDirection, 393 | Speed = AnimationSpeed, 394 | SetSubFrame = AnimationOptions.SmoothFrameInterpolation, 395 | Quality = AnimationOptions.AnimationQuality.ToDescription(), 396 | EnterFrameEvent = CurrentFrameChanged.HasDelegate, 397 | }; 398 | IsAnimationLoaded = await LottiePlayerModule.InitializeAsync(lottiePlaybackOptions); 399 | if (!IsAnimationLoaded) 400 | { 401 | throw new InvalidOperationException("Failed to initialize Lottie Animation"); 402 | } 403 | // redraw the screen to reflect the changes 404 | _initCount++; 405 | IsAnimationPaused = !lottiePlaybackOptions.AutoPlay; 406 | 407 | // setup events 408 | EventSubscription(true); 409 | 410 | StateHasChanged(); 411 | } 412 | 413 | private void EventSubscription(bool subscribe) 414 | { 415 | if (LottiePlayerModule == null) return; 416 | if (subscribe) 417 | { 418 | LottiePlayerModule.OnDOMLoaded += HandleDOMLoaded; 419 | LottiePlayerModule.OnAnimationReady += HandleAnimationReady; 420 | LottiePlayerModule.OnComplete += HandleAnimationCompleted; 421 | LottiePlayerModule.OnLoopComplete += HandleAnimationLoopCompleted; 422 | LottiePlayerModule.OnEnterFrame += HandleCurrentFrameChanged; 423 | } 424 | else 425 | { 426 | LottiePlayerModule.OnDOMLoaded -= HandleDOMLoaded; 427 | LottiePlayerModule.OnAnimationReady -= HandleAnimationReady; 428 | LottiePlayerModule.OnComplete -= HandleAnimationCompleted; 429 | LottiePlayerModule.OnLoopComplete -= HandleAnimationLoopCompleted; 430 | LottiePlayerModule.OnEnterFrame -= HandleCurrentFrameChanged; 431 | } 432 | } 433 | 434 | #region Compoinent Lifecycle 435 | 436 | /// 437 | /// OnAfterRenderAsync override 438 | /// 439 | protected override async Task OnAfterRenderAsync(bool firstRender) 440 | { 441 | if (firstRender || !_lottieLoaded) 442 | { 443 | // load the Lottie Web Player JS from CDN 444 | var initModule = await JSRuntime.InvokeAsync("import", "./_content/Blazor.Lottie.Player/loadLottieWeb.js"); 445 | // if cdn failed on 2nd try let's swap to local copy 446 | var initJs = firstRender ? AnimationOptions.LottieSourceJs : "./_content/Blazor.Lottie.Player/lottie.min.js"; 447 | _lottieLoaded = await initModule.InvokeAsync("initialize", initJs); 448 | if (!_lottieLoaded) 449 | { 450 | StateHasChanged(); 451 | return; 452 | } 453 | await InitializeLottieModule(); 454 | } 455 | } 456 | 457 | /// 458 | /// Override the SetParametersAsync method to handle component parameters. 459 | /// 460 | /// The parameters submitted with the component 461 | public override Task SetParametersAsync(ParameterView parameters) 462 | { 463 | var reInitialize = false; 464 | 465 | var oldSrc = Src; 466 | var oldAutoPlay = AutoPlay; 467 | var oldLoop = Loop; 468 | var oldLoopCount = LoopCount; 469 | var oldType = AnimationType; 470 | var oldOptions = AnimationOptions; 471 | 472 | // Apply the parameters to the component 473 | parameters.SetParameterProperties(this); 474 | 475 | // check if Src returns is json 476 | if (string.IsNullOrWhiteSpace(Src) || !Src.EndsWith(".json", StringComparison.OrdinalIgnoreCase)) 477 | { 478 | _failMessage = "Src must be a valid JSON file path ending with .json"; 479 | 480 | } 481 | 482 | // Check if any key parameters changed 483 | if (AutoPlay != oldAutoPlay || 484 | Loop != oldLoop || 485 | !Equals(AnimationType, oldType) || 486 | !Equals(AnimationOptions, oldOptions) || 487 | Src != oldSrc || 488 | LoopCount != oldLoopCount) 489 | { 490 | reInitialize = true; 491 | } 492 | 493 | if (reInitialize && _initCount > 0) 494 | { 495 | return InitializeLottieModule(); 496 | } 497 | return base.SetParametersAsync(parameters); 498 | } 499 | 500 | /// 501 | /// Disposes the LottiePlayer component asynchronously, cleaning up resources and references. 502 | /// 503 | /// 504 | public async ValueTask DisposeAsync() 505 | { 506 | if (LottiePlayerModule != null) 507 | { 508 | // cancel event handlers to prevent memory leaks 509 | EventSubscription(false); 510 | 511 | await LottiePlayerModule.DisposeAsync(); 512 | LottiePlayerModule = null; 513 | } 514 | 515 | GC.SuppressFinalize(this); 516 | } 517 | 518 | #endregion 519 | } 520 | 521 | -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player.Docs.WASM/wwwroot/lottie/newAnimation.json: -------------------------------------------------------------------------------- 1 | {"v":"4.9.0","fr":30,"ip":0,"op":38,"w":315,"h":280,"nm":"new","ddd":0,"assets":[],"layers":[{"ddd":0,"ind":1,"ty":4,"nm":"bodyband Konturen","parent":3,"sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":0,"k":0},"p":{"a":0,"k":[157.5,129,0]},"a":{"a":0,"k":[157.5,140,0]},"s":{"a":0,"k":[100,100,100]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"n":"0p667_1_0p333_0","t":9,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-14.5,52],[14.5,52],[14.5,52.25],[-14.5,52.25]],"c":true}],"e":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-14.5,-41],[14.5,-41],[14.5,52.25],[-14.5,52.25]],"c":true}]},{"t":19.111328125}]},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[0.871,0.702,0.271,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[160.5,184],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":4,"nm":"topband Konturen","parent":4,"sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":0,"k":0},"p":{"a":0,"k":[157.5,140,0]},"a":{"a":0,"k":[157.5,140,0]},"s":{"a":0,"k":[100,100,100]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"n":"0p667_1_0p333_0","t":16.777,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-14.5,-14.5],[14.5,-14.5],[15.036,-14.207],[-13.964,-14.207]],"c":true}],"e":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-14.5,-14.5],[14.5,-14.5],[14.5,14.5],[-14.5,14.5]],"c":true}]},{"t":23}]},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.831,0.396,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[160.5,128.5],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":4,"nm":"body Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":0,"s":[0],"e":[-13]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":5.432,"s":[-13],"e":[17.85]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":11.111,"s":[17.85],"e":[0]},{"t":16.2958984375}]},"p":{"a":1,"k":[{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"n":"0p667_1_0p333_0","t":0,"s":[162.125,247.599,0],"e":[162.125,145.599,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.667,"y":1},"o":{"x":0.333,"y":0},"n":"0p667_1_0p333_0","t":8.148,"s":[162.125,145.599,0],"e":[162.125,236.099,0],"to":[0,0,0],"ti":[0,0,0]},{"t":16.2958984375}]},"a":{"a":0,"k":[162.125,225.099,0]},"s":{"a":0,"k":[100,100,100]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"n":"0p833_0p833_0p167_0p167","t":0,"s":[{"i":[[0,0],[0,0],[0,0],[-3.228,0],[0,0],[-2.75,0.062]],"o":[[0,0],[0,0],[4.75,-0.188],[0,0],[3.228,0],[0,0]],"v":[[56.25,46.5],[-54.75,46.5],[-55,46.688],[-49.658,46.5],[49.658,46.5],[56,46.688]],"c":true}],"e":[{"i":[[0,0],[0,0],[0,0],[-3.228,0],[0,0],[0,3.21]],"o":[[0,0],[0,0],[0,3.21],[0,0],[3.228,0],[0,0]],"v":[[55.5,-46.5],[-55.5,-46.5],[-55.5,40.688],[-49.658,46.5],[49.658,46.5],[55.5,40.688]],"c":true}]},{"t":3.7041015625}]},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[0.008,0.588,0.847,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[161.5,178.5],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":4,"ty":4,"nm":"top Konturen","sr":1,"ks":{"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":3.704,"s":[0],"e":[100]},{"t":4.4443359375}]},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":8.148,"s":[10],"e":[-23]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":14.074,"s":[-23],"e":[0]},{"t":20}]},"p":{"a":1,"k":[{"i":{"x":0.937,"y":0.946},"o":{"x":0.167,"y":0.167},"n":"0p937_0p946_0p167_0p167","t":0,"s":[160,177.5,0],"e":[150,34.5,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.097,"y":0},"o":{"x":0.084,"y":0.101},"n":"0p097_0_0p084_0p101","t":10.37,"s":[150,34.5,0],"e":[161,128.5,0],"to":[0,0,0],"ti":[0,0,0]},{"t":20}]},"a":{"a":0,"k":[161,128.5,0]},"s":{"a":1,"k":[{"i":{"x":[0.667,0.667,0.667],"y":[1,1,1]},"o":{"x":[0.333,0.333,0.333],"y":[0,0,0]},"n":["0p667_1_0p333_0","0p667_1_0p333_0","0p667_1_0p333_0"],"t":0,"s":[0,0,100],"e":[58.621,58.621,100]},{"i":{"x":[0.667,0.667,0.667],"y":[1,1,1]},"o":{"x":[0.333,0.333,0.333],"y":[0,0,0]},"n":["0p667_1_0p333_0","0p667_1_0p333_0","0p667_1_0p333_0"],"t":10.37,"s":[58.621,58.621,100],"e":[100,100,100]},{"t":20}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[3.219,0],[0,0],[0,-3.204],[0,0],[-3.219,0],[0,0],[0,3.204],[0,0]],"o":[[0,0],[-3.219,0],[0,0],[0,3.204],[0,0],[3.219,0],[0,0],[0,-3.204]],"v":[[61.174,-14.5],[-61.174,-14.5],[-67,-8.7],[-67,8.7],[-61.174,14.5],[61.174,14.5],[67,8.7],[67,-8.7]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[0.012,0.663,0.957,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[161,128.5],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":5,"ty":4,"nm":"schleife/new Konturen","parent":4,"sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":0,"k":0},"p":{"a":0,"k":[161,115,0]},"a":{"a":0,"k":[161,115,0]},"s":{"a":1,"k":[{"i":{"x":[0.029,0.029,0.833],"y":[1.656,1.656,-15.667]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p029_1p656_0p167_0p167","0p029_1p656_0p167_0p167","0p833_-15p667_0p167_16p667"],"t":23,"s":[0,0,100],"e":[100,100,100]},{"t":34}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[8.059,0],[1.667,-0.428],[-0.598,-1.849],[-1.278,0],[0,-4.797],[4.835,0],[0,0],[-8.693,2.139],[0.541,1.87],[3.006,-6.366],[4.932,3.716],[1.157,-1.595],[-1.586,-3.998],[0,0],[0,4.796],[-4.834,0],[-2.606,-1.934],[-1.272,1.478],[5.256,0],[0,-7.995],[-8.058,0],[0,0],[0,0],[0,7.995]],"o":[[-1.91,0],[0.541,1.87],[1.145,-0.282],[4.835,0],[0,4.796],[0,0],[2.097,-5.318],[-0.598,-1.849],[-9.385,2.413],[-2.071,-4.386],[-1.272,1.478],[5.152,3.823],[0,0],[-4.834,0],[0,-4.797],[3.679,0],[1.157,-1.595],[-3.498,-2.637],[-8.058,0],[0,7.995],[0,0],[0,0],[8.059,0],[0,-7.995]],"v":[[23.385,-14.5],[18.024,-13.831],[19.756,-8.259],[23.385,-8.7],[32.155,0],[23.385,8.7],[4.075,8.7],[19.756,-8.259],[18.024,-13.831],[0,3.422],[-10.322,-10.065],[-13.987,-5.478],[-4.083,8.7],[-23.385,8.7],[-32.154,0],[-23.385,-8.7],[-13.987,-5.478],[-10.322,-10.065],[-23.385,-14.5],[-38,0],[-23.385,14.5],[0,14.5],[23.385,14.5],[38,0]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.831,0.396,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[161,100.5],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":6,"ty":4,"nm":"shadow Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":0,"k":0},"p":{"a":0,"k":[162,236,0]},"a":{"a":0,"k":[162,225,0]},"s":{"a":1,"k":[{"i":{"x":[0.115,0.115,0.833],"y":[1,1,-5.19]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p115_1_0p167_0p167","0p115_1_0p167_0p167","0p833_-5p19_0p167_16p667"],"t":0,"s":[0,0,100],"e":[100,100,100]},{"t":13}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-53.02,0],[0,-3.313],[53.02,0],[0,3.313]],"o":[[53.02,0],[0,3.313],[-53.02,0],[0,-3.313]],"v":[[0,-6],[96,0],[0,6],[-96,0]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[0.945,0.945,0.945,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[162,225],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":7,"ty":4,"nm":"Ebene 12 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":9,"s":[262],"e":[0]},{"t":29}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.359},"o":{"x":0.167,"y":0.167},"n":"0_0p359_0p167_0p167","t":9,"s":[157.5,140,0],"e":[95.449,44.997,0],"to":[0,0,0],"ti":[0,0,0]},{"t":29}]},"a":{"a":0,"k":[95.449,44.997,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":9,"s":[0,0,100],"e":[100,100,100]},{"t":29}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-2.18,-3.777],[2.178,-3.775],[4.359,0.001],[2.181,3.777],[-2.18,3.775],[-4.359,-0.001]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"st","c":{"a":0,"k":[0.012,0.663,0.957,1]},"o":{"a":0,"k":100},"w":{"a":0,"k":1},"lc":1,"lj":1,"ml":4,"nm":"Kontur 1","mn":"ADBE Vector Graphic - Stroke"},{"ty":"tr","p":{"a":0,"k":[95.449,44.997],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":8,"ty":4,"nm":"Ebene 13 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":3,"s":[-63],"e":[0]},{"t":23}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.564},"o":{"x":0.167,"y":0.167},"n":"0_0p564_0p167_0p167","t":3,"s":[157.5,140,0],"e":[248.067,112.75,0],"to":[0,0,0],"ti":[0,0,0]},{"t":23}]},"a":{"a":0,"k":[248.067,112.75,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":3,"s":[0,0,100],"e":[100,100,100]},{"t":23}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-1.53,-6.63],[4.974,-4.639],[6.505,1.99],[1.532,6.63],[-4.972,4.64],[-6.505,-1.989]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"st","c":{"a":0,"k":[0.012,0.663,0.957,1]},"o":{"a":0,"k":100},"w":{"a":0,"k":1},"lc":1,"lj":1,"ml":4,"nm":"Kontur 1","mn":"ADBE Vector Graphic - Stroke"},{"ty":"tr","p":{"a":0,"k":[248.067,112.75],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":9,"ty":4,"nm":"Ebene 14 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":0,"s":[-200],"e":[0]},{"t":20}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.477},"o":{"x":0.167,"y":0.167},"n":"0_0p477_0p167_0p167","t":0,"s":[157.5,140,0],"e":[268.728,57.196,0],"to":[0,0,0],"ti":[0,0,0]},{"t":20}]},"a":{"a":0,"k":[120.728,247.196,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":0,"s":[0,0,100],"e":[100,100,100]},{"t":20}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0]],"v":[[-2.376,-3.394],[2.799,1.018],[-2.799,3.394]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"st","c":{"a":0,"k":[0.149,0.784,0.333,1]},"o":{"a":0,"k":100},"w":{"a":0,"k":1},"lc":1,"lj":1,"ml":4,"nm":"Kontur 1","mn":"ADBE Vector Graphic - Stroke"},{"ty":"tr","p":{"a":0,"k":[120.728,247.196],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":10,"ty":4,"nm":"Ebene 15 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":8,"s":[134],"e":[0]},{"t":28}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.547},"o":{"x":0.167,"y":0.167},"n":"0_0p547_0p167_0p167","t":8,"s":[157.5,140,0],"e":[61.63,139.445,0],"to":[0,0,0],"ti":[0,0,0]},{"t":28}]},"a":{"a":0,"k":[61.63,139.445,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":8,"s":[0,0,100],"e":[100,100,100]},{"t":28}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0]],"v":[[4.37,-5.433],[4.286,5.433],[-4.37,1.022]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"st","c":{"a":0,"k":[0.149,0.784,0.333,1]},"o":{"a":0,"k":100},"w":{"a":0,"k":1},"lc":1,"lj":1,"ml":4,"nm":"Kontur 1","mn":"ADBE Vector Graphic - Stroke"},{"ty":"tr","p":{"a":0,"k":[61.63,139.445],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":11,"ty":4,"nm":"Ebene 16 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":5,"s":[74],"e":[0]},{"t":25}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.387},"o":{"x":0.167,"y":0.167},"n":"0_0p387_0p167_0p167","t":5,"s":[157.5,140,0],"e":[183.561,32.661,0],"to":[0,0,0],"ti":[0,0,0]},{"t":25}]},"a":{"a":0,"k":[183.561,32.661,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":5,"s":[0,0,100],"e":[100,100,100]},{"t":25}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-2.146,0],[0,-2.147],[2.146,0],[0,2.147]],"o":[[2.146,0],[0,2.147],[-2.146,0],[0,-2.147]],"v":[[-0.001,-3.888],[3.886,0],[-0.001,3.888],[-3.887,0]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"st","c":{"a":0,"k":[0.039,0.314,0.392,1]},"o":{"a":0,"k":100},"w":{"a":0,"k":1},"lc":1,"lj":1,"ml":4,"nm":"Kontur 1","mn":"ADBE Vector Graphic - Stroke"},{"ty":"tr","p":{"a":0,"k":[183.561,32.661],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":12,"ty":4,"nm":"Ebene 17 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":12,"s":[29],"e":[0]},{"t":32}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.463},"o":{"x":0.167,"y":0.167},"n":"0_0p463_0p167_0p167","t":12,"s":[157.5,140,0],"e":[44.65,36.558,0],"to":[0,0,0],"ti":[0,0,0]},{"t":32}]},"a":{"a":0,"k":[214.65,244.558,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":12,"s":[0,0,100],"e":[100,100,100]},{"t":32}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-3.22,0],[0,-3.222],[3.22,0],[0,3.221]],"o":[[3.22,0],[0,3.221],[-3.22,0],[0,-3.222]],"v":[[0,-5.832],[5.829,0],[0,5.832],[-5.829,0]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"st","c":{"a":0,"k":[0.039,0.314,0.392,1]},"o":{"a":0,"k":100},"w":{"a":0,"k":1},"lc":1,"lj":1,"ml":4,"nm":"Kontur 1","mn":"ADBE Vector Graphic - Stroke"},{"ty":"tr","p":{"a":0,"k":[214.65,244.558],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":13,"ty":4,"nm":"Ebene 18 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":3,"s":[168],"e":[0]},{"t":23}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.243},"o":{"x":0.167,"y":0.167},"n":"0_0p243_0p167_0p167","t":3,"s":[157.5,140,0],"e":[294.925,112.226,0],"to":[0,0,0],"ti":[0,0,0]},{"t":23}]},"a":{"a":0,"k":[62.925,234.226,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":3,"s":[0,0,100],"e":[100,100,100]},{"t":23}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.209,0.131],[0,0],[0,0],[0.174,-0.142],[0,0],[0,0],[-0.093,-0.228],[0,0],[0,0],[-0.247,0.014],[0,0],[0,0],[-0.059,0.236],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.012,-0.223],[0,0],[0,0],[-0.238,-0.069],[0,0],[0,0],[-0.135,0.201],[0,0],[0,0],[0.155,0.19],[0,0],[0,0],[0.232,-0.083]],"v":[[2.206,-0.077],[1.1,-0.771],[1.036,-2.051],[0.544,-2.269],[-0.45,-1.461],[-1.706,-1.819],[-2.062,-1.431],[-1.568,-0.237],[-2.281,0.82],[-2.008,1.278],[-0.711,1.208],[0.105,2.221],[0.628,2.116],[0.938,0.878],[2.156,0.446]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[62.916,234.223],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":14,"ty":4,"nm":"Ebene 19 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":8,"s":[-209],"e":[0]},{"t":28}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.25},"o":{"x":0.167,"y":0.167},"n":"0_0p25_0p167_0p167","t":8,"s":[157.5,140,0],"e":[35.721,103.978,0],"to":[0,0,0],"ti":[0,0,0]},{"t":28}]},"a":{"a":0,"k":[35.721,103.978,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":8,"s":[0,0,100],"e":[100,100,100]},{"t":28}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.209,0.131],[0,0],[0,0],[0.174,-0.141],[0,0],[0,0],[-0.094,-0.227],[0,0],[0,0],[-0.247,0.014],[0,0],[0,0],[-0.059,0.237],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.012,-0.224],[0,0],[0,0],[-0.238,-0.068],[0,0],[0,0],[-0.135,0.2],[0,0],[0,0],[0.155,0.191],[0,0],[0,0],[0.231,-0.083]],"v":[[2.206,-0.078],[1.1,-0.771],[1.036,-2.051],[0.544,-2.27],[-0.45,-1.461],[-1.706,-1.82],[-2.062,-1.432],[-1.568,-0.238],[-2.281,0.82],[-2.008,1.278],[-0.711,1.207],[0.105,2.22],[0.628,2.115],[0.938,0.878],[2.156,0.446]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[35.712,103.975],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":15,"ty":4,"nm":"Ebene 20 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":7,"s":[275],"e":[0]},{"t":27}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.09},"o":{"x":0.167,"y":0.167},"n":"0_0p09_0p167_0p167","t":7,"s":[157.5,140,0],"e":[261.12,26.218,0],"to":[0,0,0],"ti":[0,0,0]},{"t":27}]},"a":{"a":0,"k":[261.12,26.218,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":7,"s":[0,0,100],"e":[100,100,100]},{"t":27}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.21,0.131],[0,0],[0,0],[0.174,-0.141],[0,0],[0,0],[-0.093,-0.228],[0,0],[0,0],[-0.247,0.014],[0,0],[0,0],[-0.059,0.236],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.011,-0.223],[0,0],[0,0],[-0.238,-0.068],[0,0],[0,0],[-0.135,0.2],[0,0],[0,0],[0.155,0.19],[0,0],[0,0],[0.232,-0.082]],"v":[[2.206,-0.078],[1.099,-0.771],[1.034,-2.052],[0.543,-2.27],[-0.45,-1.461],[-1.707,-1.82],[-2.062,-1.432],[-1.568,-0.238],[-2.281,0.82],[-2.009,1.278],[-0.711,1.207],[0.105,2.22],[0.628,2.115],[0.937,0.878],[2.155,0.445]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[261.111,26.215],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":16,"ty":4,"nm":"Ebene 21 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":3,"s":[132.9],"e":[0]},{"t":23}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.326},"o":{"x":0.167,"y":0.167},"n":"0_0p326_0p167_0p167","t":3,"s":[157.5,140,0],"e":[268.337,196.938,0],"to":[0,0,0],"ti":[0,0,0]},{"t":23}]},"a":{"a":0,"k":[252.337,213.938,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":3,"s":[0,0,100],"e":[100,100,100]},{"t":23}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.411,0.258],[0,0],[0,0],[0.34,-0.276],[0,0],[0,0],[-0.184,-0.446],[0,0],[0,0],[-0.483,0.027],[0,0],[0,0],[-0.116,0.463],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.022,-0.439],[0,0],[0,0],[-0.466,-0.133],[0,0],[0,0],[-0.265,0.392],[0,0],[0,0],[0.302,0.373],[0,0],[0,0],[0.454,-0.162]],"v":[[4.322,-0.152],[2.152,-1.51],[2.027,-4.017],[1.065,-4.447],[-0.882,-2.861],[-3.344,-3.565],[-4.038,-2.804],[-3.072,-0.465],[-4.468,1.607],[-3.935,2.505],[-1.392,2.366],[0.207,4.35],[1.231,4.145],[1.837,1.72],[4.222,0.874]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[252.32,213.932],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":17,"ty":4,"nm":"Ebene 22 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":13,"s":[-266],"e":[0]},{"t":33}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.337},"o":{"x":0.167,"y":0.167},"n":"0_0p337_0p167_0p167","t":13,"s":[157.5,140,0],"e":[133.395,26.515,0],"to":[0,0,0],"ti":[0,0,0]},{"t":33}]},"a":{"a":0,"k":[133.395,26.515,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":13,"s":[0,0,100],"e":[100,100,100]},{"t":33}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.411,0.258],[0,0],[0,0],[0.34,-0.277],[0,0],[0,0],[-0.183,-0.446],[0,0],[0,0],[-0.484,0.026],[0,0],[0,0],[-0.116,0.462],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.022,-0.438],[0,0],[0,0],[-0.466,-0.133],[0,0],[0,0],[-0.264,0.392],[0,0],[0,0],[0.302,0.373],[0,0],[0,0],[0.454,-0.162]],"v":[[4.322,-0.152],[2.152,-1.511],[2.027,-4.018],[1.065,-4.446],[-0.882,-2.861],[-3.344,-3.565],[-4.039,-2.804],[-3.072,-0.466],[-4.469,1.607],[-3.935,2.505],[-1.392,2.366],[0.207,4.35],[1.231,4.145],[1.837,1.72],[4.222,0.874]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[133.378,26.508],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":18,"ty":4,"nm":"Ebene 23 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":5,"s":[399],"e":[0]},{"t":25}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.478},"o":{"x":0.167,"y":0.167},"n":"0_0p478_0p167_0p167","t":5,"s":[157.5,140,0],"e":[257.258,159.497,0],"to":[0,0,0],"ti":[0,0,0]},{"t":25}]},"a":{"a":0,"k":[257.258,159.497,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":5,"s":[0,0,100],"e":[100,100,100]},{"t":25}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.721,-0.604],[0,0],[0,0],[-0.306,-0.794],[0,0],[0,0],[-0.932,0.071],[0,0],[0,0],[-0.241,0.908],[0,0],[0,0],[0.783,0.491],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.821,-0.221],[0,0],[0,0],[-0.524,0.78],[0,0],[0,0],[0.566,0.723],[0,0],[0,0],[0.869,-0.333],[0,0],[0,0],[-0.027,-0.935]],"v":[[2.281,-8.697],[-1.528,-5.509],[-6.23,-6.781],[-7.598,-5.261],[-5.84,-0.719],[-8.615,3.403],[-7.627,5.141],[-2.732,4.758],[0.255,8.578],[2.232,8.133],[3.5,3.356],[8.121,1.595],[8.357,-0.417],[4.245,-2.989],[4.113,-7.897]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[257.231,159.483],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":19,"ty":4,"nm":"Ebene 24 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":11,"s":[-212],"e":[0]},{"t":31}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.748},"o":{"x":0.167,"y":0.167},"n":"0_0p748_0p167_0p167","t":11,"s":[157.5,140,0],"e":[97.064,84.204,0],"to":[0,0,0],"ti":[0,0,0]},{"t":31}]},"a":{"a":0,"k":[97.064,84.204,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":11,"s":[0,0,100],"e":[100,100,100]},{"t":31}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.675,-0.565],[0,0],[0,0],[-0.287,-0.743],[0,0],[0,0],[-0.872,0.067],[0,0],[0,0],[-0.226,0.849],[0,0],[0,0],[0.734,0.459],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.77,-0.208],[0,0],[0,0],[-0.491,0.73],[0,0],[0,0],[0.53,0.677],[0,0],[0,0],[0.814,-0.312],[0,0],[0,0],[-0.026,-0.875]],"v":[[2.135,-8.142],[-1.43,-5.157],[-5.831,-6.348],[-7.113,-4.926],[-5.467,-0.674],[-8.064,3.186],[-7.141,4.812],[-2.557,4.454],[0.239,8.029],[2.09,7.613],[3.277,3.141],[7.602,1.493],[7.822,-0.391],[3.974,-2.799],[3.851,-7.393]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[97.039,84.191],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":20,"ty":4,"nm":"Ebene 25 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":3,"s":[-256],"e":[0]},{"t":23}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.718},"o":{"x":0.167,"y":0.167},"n":"0_0p718_0p167_0p167","t":3,"s":[157.5,140,0],"e":[78.559,168.874,0],"to":[0,0,0],"ti":[0,0,0]},{"t":23}]},"a":{"a":0,"k":[78.559,168.874,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":3,"s":[0,0,100],"e":[100,100,100]},{"t":23}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.516,-0.432],[0,0],[0,0],[-0.219,-0.569],[0,0],[0,0],[-0.668,0.051],[0,0],[0,0],[-0.173,0.65],[0,0],[0,0],[0.562,0.351],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.588,-0.159],[0,0],[0,0],[-0.376,0.559],[0,0],[0,0],[0.405,0.518],[0,0],[0,0],[0.623,-0.239],[0,0],[0,0],[-0.02,-0.669]],"v":[[1.633,-6.229],[-1.096,-3.945],[-4.463,-4.856],[-5.442,-3.768],[-4.183,-0.516],[-6.17,2.436],[-5.463,3.681],[-1.958,3.407],[0.182,6.143],[1.598,5.824],[2.507,2.403],[5.814,1.142],[5.984,-0.299],[3.04,-2.141],[2.945,-5.656]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[78.54,168.865],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":21,"ty":4,"nm":"Ebene 26 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":17,"s":[50],"e":[18]},{"t":37}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.897},"o":{"x":0.167,"y":0.167},"n":"0_0p897_0p167_0p167","t":17,"s":[157.5,140,0],"e":[155.771,214.44,0],"to":[0,0,0],"ti":[0,0,0]},{"t":37}]},"a":{"a":0,"k":[155.771,214.44,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.008,1.008,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,15.952]},"n":["0p042_1p008_0p167_0p167","0p042_1p008_0p167_0p167","0p833_-26p778_0p167_15p952"],"t":17,"s":[0,0,100],"e":[67,67,100]},{"t":37}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[1.312,-0.183],[0,0],[0,0],[0.227,-1.177],[0,0],[0,0],[-1.168,-0.61],[0,0],[0,0],[-0.967,0.904],[0,0],[0,0],[0.57,1.171],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.816,-0.879],[0,0],[0,0],[-1.21,0.541],[0,0],[0,0],[0.137,1.287],[0,0],[0,0],[1.289,0.251],[0,0],[0,0],[0.665,-1.137]],"v":[[10.542,-8.02],[3.609,-7.053],[-1.06,-12.084],[-3.829,-11.291],[-5.121,-4.55],[-11.514,-1.696],[-11.632,1.119],[-5.496,4.318],[-4.779,11.114],[-2.084,12.058],[2.999,7.295],[9.835,8.642],[11.62,6.414],[8.627,0.269],[12.136,-5.695]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[155.828,214.455],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0},{"ddd":0,"ind":22,"ty":4,"nm":"Ebene 27 Konturen","sr":1,"ks":{"o":{"a":0,"k":100},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"n":["0p833_0p833_0p167_0p167"],"t":11,"s":[-239],"e":[0]},{"t":31}]},"p":{"a":1,"k":[{"i":{"x":0,"y":0.5},"o":{"x":0.167,"y":0.167},"n":"0_0p5_0p167_0p167","t":11,"s":[157.5,140,0],"e":[219.606,61.933,0],"to":[0,0,0],"ti":[0,0,0]},{"t":31}]},"a":{"a":0,"k":[219.606,61.933,0]},"s":{"a":1,"k":[{"i":{"x":[0.042,0.042,0.833],"y":[1.006,1.006,-26.778]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,16.667]},"n":["0p042_1p006_0p167_0p167","0p042_1p006_0p167_0p167","0p833_-26p778_0p167_16p667"],"t":11,"s":[0,0,100],"e":[100,100,100]},{"t":31}]}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0.946,-0.131],[0,0],[0,0],[0.163,-0.849],[0,0],[0,0],[-0.842,-0.44],[0,0],[0,0],[-0.697,0.652],[0,0],[0,0],[0.411,0.845],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.588,-0.633],[0,0],[0,0],[-0.872,0.39],[0,0],[0,0],[0.099,0.928],[0,0],[0,0],[0.929,0.181],[0,0],[0,0],[0.479,-0.819]],"v":[[7.601,-5.783],[2.602,-5.086],[-0.764,-8.713],[-2.76,-8.141],[-3.693,-3.281],[-8.301,-1.223],[-8.387,0.807],[-3.962,3.114],[-3.445,8.013],[-1.503,8.694],[2.163,5.259],[7.09,6.23],[8.378,4.624],[6.219,0.195],[8.749,-4.107]],"c":true}},"nm":"Pfad 1","mn":"ADBE Vector Shape - Group"},{"ty":"fl","c":{"a":0,"k":[1,0.729,0.031,1]},"o":{"a":0,"k":100},"r":1,"nm":"Fläche 1","mn":"ADBE Vector Graphic - Fill"},{"ty":"tr","p":{"a":0,"k":[219.647,61.944],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transformieren"}],"nm":"Gruppe 1","np":2,"cix":2,"ix":1,"mn":"ADBE Vector Group"}],"ip":0,"op":150,"st":0,"bm":0}]} -------------------------------------------------------------------------------- /src/Blazor.Lottie.Player/wwwroot/loading.json: -------------------------------------------------------------------------------- 1 | {"v":"5.5.7","meta":{"g":"LottieFiles AE 0.1.21","a":"","k":"","d":"","tc":""},"fr":60,"ip":0,"op":43,"w":512,"h":512,"nm":"Loading Animation Bored Hand","ddd":0,"assets":[],"layers":[{"ddd":0,"ind":2,"ty":4,"nm":"LOADING Outlines","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[255.892,367,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-33.44,0],[-33.44,-3.04],[-39.767,-3.04],[-39.767,-13.566],[-43.301,-13.566],[-43.301,0]],"c":true},"ix":2},"nm":"L","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.266666666667,0.266666666667,0.266666666667,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":0,"s":[0,0],"to":[0,-0.569],"ti":[0,1.578]},{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":5,"s":[0,-3.686],"to":[0,-2.122],"ti":[0,-0.614]},{"t":9.34765625,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"L","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[-1.166,-1.304],[-2.078,0],[-1.216,1.368],[0,2.04],[1.165,1.305],[2.077,0],[1.216,-1.368],[0,-2.039]],"o":[[1.216,1.368],[2.077,0],[1.165,-1.304],[0,-2.039],[-1.216,-1.368],[-2.078,0],[-1.166,1.305],[0,2.04]],"v":[[-30.457,-1.767],[-25.517,0.285],[-20.577,-1.767],[-18.829,-6.783],[-20.577,-11.799],[-25.517,-13.851],[-30.457,-11.799],[-32.205,-6.783]],"c":true},"ix":2},"nm":"O","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[-0.482,0.722],[-1.064,0],[-0.558,-0.836],[0,-1.127],[0.481,-0.722],[1.064,0],[0.557,0.836],[0,1.128]],"o":[[0.557,-0.836],[1.064,0],[0.481,0.722],[0,1.128],[-0.558,0.836],[-1.064,0],[-0.482,-0.722],[0,-1.127]],"v":[[-27.949,-9.557],[-25.517,-10.811],[-23.085,-9.557],[-22.363,-6.783],[-23.085,-4.009],[-25.517,-2.755],[-27.949,-4.009],[-28.671,-6.783]],"c":true},"ix":2},"nm":"O","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.266666666667,0.266666666667,0.266666666667,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":5,"s":[0,0],"to":[0,-0.525],"ti":[0,1.447]},{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":11,"s":[0,-3.326],"to":[0,-2.226],"ti":[0,-0.554]},{"t":14.95703125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"O","np":4,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-11.419,-9.804],[-9.918,-5.054],[-12.996,-5.054],[-11.457,-9.804]],"c":true},"ix":2},"nm":"A","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-14.668,0],[-13.813,-2.432],[-9.082,-2.432],[-8.246,0],[-4.56,0],[-9.633,-13.566],[-13.224,-13.566],[-18.297,0]],"c":true},"ix":2},"nm":"A","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.266666666667,0.266666666667,0.266666666667,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":11,"s":[0,0],"to":[0,-0.552],"ti":[0,1.53]},{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":16,"s":[0,-3.55],"to":[0,-2.163],"ti":[0,-0.592]},{"t":20.564453125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"A","np":4,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[-1.172,1.178],[0,2.204],[1.178,1.191],[2.077,0],[0,0],[0,0]],"o":[[2.09,0],[1.171,-1.178],[0,-2.102],[-1.178,-1.19],[0,0],[0,0],[0,0]],"v":[[2.299,0],[7.192,-1.767],[8.949,-6.84],[7.182,-11.78],[2.299,-13.566],[-3.534,-13.566],[-3.534,0]],"c":true},"ix":2},"nm":"D","mn":"ADBE Vector Shape - Group","hd":false},{"ind":1,"ty":"sh","ix":2,"ks":{"a":0,"k":{"i":[[0,0],[0,-2.444],[0.576,-0.595],[1.342,0],[0,0],[0,0]],"o":[[2.495,0],[0,1.356],[-0.577,0.596],[0,0],[0,0],[0,0]],"v":[[1.672,-10.526],[5.415,-6.859],[4.551,-3.933],[1.672,-3.04],[0,-3.04],[0,-10.526]],"c":true},"ix":2},"nm":"D","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.266666666667,0.266666666667,0.266666666667,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":16,"s":[0,0],"to":[0,-0.512],"ti":[0,1.404]},{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":22,"s":[0,-3.212],"to":[0,-2.255],"ti":[0,-0.535]},{"t":26.173828125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"D","np":4,"cix":2,"bm":0,"ix":4,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[14.421,0],[14.421,-13.566],[10.887,-13.566],[10.887,0]],"c":true},"ix":2},"nm":"I","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.266666666667,0.266666666667,0.266666666667,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":22,"s":[0,0],"to":[0,-0.537],"ti":[0,1.483]},{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":28,"s":[0,-3.423],"to":[0,-2.199],"ti":[0,-0.57]},{"t":31.783203125,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"I","np":3,"cix":2,"bm":0,"ix":5,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[20.159,0],[20.159,-8.455],[24.892,0],[28.538,0],[28.538,-13.566],[25.213,-13.566],[25.213,-5.206],[20.479,-13.566],[16.834,-13.566],[16.834,0]],"c":true},"ix":2},"nm":"N","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.266666666667,0.266666666667,0.266666666667,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":28,"s":[0,0],"to":[0,-0.565],"ti":[0,1.569]},{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":33,"s":[0,-3.659],"to":[0,-2.13],"ti":[0,-0.61]},{"t":37.390625,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"N","np":3,"cix":2,"bm":0,"ix":6,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0.557,-0.373],[0.861,0],[0.557,0.836],[0,1.128],[-0.482,0.722],[-1.064,0],[-0.507,-0.335],[-0.051,-0.57],[0,0],[1.266,0.887],[1.545,0],[1.247,-1.349],[0,-2.014],[-1.229,-1.33],[-2.014,0],[-0.836,1.178],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[-0.102,0.621],[-0.558,0.374],[-1.064,0],[-0.482,-0.722],[0,-1.127],[0.557,-0.836],[0.722,0],[0.506,0.336],[0,0],[-0.152,-1.596],[-1.128,-0.785],[-2.014,0],[-1.248,1.349],[0,2.014],[1.266,1.368],[1.684,0],[0,0],[0,0],[0,0],[0,0]],"v":[[37.772,-7.429],[37.772,-4.807],[40.242,-4.807],[39.254,-3.316],[37.126,-2.755],[34.694,-4.009],[33.972,-6.783],[34.694,-9.557],[37.126,-10.811],[38.969,-10.307],[39.805,-8.949],[43.339,-8.949],[41.211,-12.673],[37.202,-13.851],[32.309,-11.827],[30.438,-6.783],[32.281,-1.767],[37.202,0.285],[40.983,-1.482],[41.192,0],[43.472,0],[43.472,-7.429]],"c":true},"ix":2},"nm":"G","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.266666666667,0.266666666667,0.266666666667,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":1,"k":[{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":33,"s":[0,0],"to":[0,-0.522],"ti":[0,1.438]},{"i":{"x":0,"y":1},"o":{"x":1,"y":0},"t":39,"s":[0,-3.302],"to":[0,-2.232],"ti":[0,-0.55]},{"t":43,"s":[0,0]}],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"G","np":3,"cix":2,"bm":0,"ix":7,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":80,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":4,"nm":"Index_finger","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[256,256,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[9.888,1.745],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[2.25,-4],[-0.25,-0.25]],"v":[[30,-130.75],[17,-130.25],[6.75,-118],[8,-67.75],[22.25,-57.75],[38.75,-68],[40.5,-116.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":6,"s":[{"i":[[9.888,1.745],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[2.25,-4],[-0.25,-0.25]],"v":[[30,-133.122],[17,-132.622],[6.75,-120.372],[8.279,-69.564],[22.529,-59.564],[39.029,-69.814],[40.5,-118.622]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[9.888,1.745],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[2.25,-4],[-0.25,-0.25]],"v":[[30,-129.599],[17,-129.099],[6.75,-116.849],[8.512,-65.576],[22.762,-55.576],[39.262,-65.826],[40.5,-115.099]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":22,"s":[{"i":[[9.5,3.948],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-1.278,4.408],[0.25,0.25]],"o":[[-7.971,-3.312],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[3.727,-12.849],[-0.25,-0.25]],"v":[[30,-72.948],[15.5,-73.948],[5.25,-61.698],[30.523,35.599],[44.773,45.599],[61.273,35.349],[45.5,-45.948]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":30,"s":[{"i":[[9.5,3.948],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-1.278,4.408],[0.25,0.25]],"o":[[-7.971,-3.312],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[3.727,-12.849],[-0.25,-0.25]],"v":[[30,-72.948],[15.5,-73.948],[5.25,-61.698],[30.523,35.599],[44.773,45.599],[61.273,35.349],[45.5,-45.948]],"c":true}]},{"t":43,"s":[{"i":[[9.888,1.745],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[2.25,-4],[-0.25,-0.25]],"v":[[30,-130.75],[17,-130.25],[6.75,-118],[8,-67.75],[22.25,-57.75],[38.75,-68],[40.5,-116.25]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.419607877731,0,0.454901993275,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 3","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[9.888,1.745],[0,0],[-3.25,-11.25],[1.637,-12.477],[-1.239,-0.169],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[3.492,12.089],[-0.826,6.293],[5.5,0.75],[2.25,-4],[-0.25,-0.25]],"v":[[30,-130.75],[17,-130.25],[29,-118.25],[29.75,-75.25],[26.75,-58.5],[38.75,-68],[40.5,-116.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":6,"s":[{"i":[[9.888,1.745],[0,0],[-3.25,-11.25],[1.637,-12.477],[-1.239,-0.169],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[3.492,12.089],[-0.826,6.293],[5.5,0.75],[2.25,-4],[-0.25,-0.25]],"v":[[29.75,-133],[16.75,-132.5],[28.75,-120.5],[29.5,-77.5],[26.5,-60.75],[38.5,-70.25],[40.25,-118.5]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[9.888,1.745],[0,0],[-3.25,-11.25],[1.637,-12.477],[-1.239,-0.169],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[3.492,12.089],[-0.826,6.293],[5.5,0.75],[2.25,-4],[-0.25,-0.25]],"v":[[30,-128.75],[17,-128.25],[29,-116.25],[29.75,-73.25],[26.75,-56.5],[38.75,-66],[40.5,-114.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":22,"s":[{"i":[[9.888,1.745],[0,0],[-3.25,-11.25],[-0.75,-13.25],[-1.235,-0.19],[-0.744,4.529],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[3.492,12.089],[0.359,6.336],[3.25,0.5],[2.75,-16.75],[-0.25,-0.25]],"v":[[28,-73.75],[13,-73.25],[29.5,-59.75],[52.75,28],[52.25,44],[61.75,35.25],[43.75,-52.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":30,"s":[{"i":[[9.888,1.745],[0,0],[-3.25,-11.25],[-0.75,-13.25],[-1.235,-0.19],[-0.744,4.529],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[3.492,12.089],[0.359,6.336],[3.25,0.5],[2.75,-16.75],[-0.25,-0.25]],"v":[[28,-73.75],[13,-73.25],[29.5,-59.75],[52.75,28],[52.25,44],[61.75,35.25],[43.75,-52.25]],"c":true}]},{"t":43,"s":[{"i":[[9.888,1.745],[0,0],[-3.25,-11.25],[1.637,-12.477],[-1.239,-0.169],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[3.492,12.089],[-0.826,6.293],[5.5,0.75],[2.25,-4],[-0.25,-0.25]],"v":[[30,-130.75],[17,-130.25],[29,-118.25],[29.75,-75.25],[26.75,-58.5],[38.75,-68],[40.5,-116.25]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.050980392156862744,0.4627450980392157,0.9450980392156862,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 2","np":3,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[9.888,1.745],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[2.25,-4],[-0.25,-0.25]],"v":[[30,-130.75],[17,-130.25],[6.75,-118],[8,-67.75],[22.25,-57.75],[38.75,-68],[40.5,-116.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":6,"s":[{"i":[[9.888,1.745],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[2.25,-4],[-0.25,-0.25]],"v":[[30,-133.122],[17,-132.622],[6.75,-120.372],[8.279,-69.564],[22.529,-59.564],[39.029,-69.814],[40.5,-118.622]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[9.888,1.745],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[2.25,-4],[-0.25,-0.25]],"v":[[30,-129.599],[17,-129.099],[6.75,-116.849],[8.512,-65.576],[22.762,-55.576],[39.262,-65.826],[40.5,-115.099]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":22,"s":[{"i":[[9.5,3.948],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-1.278,4.408],[0.25,0.25]],"o":[[-7.971,-3.312],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[3.727,-12.849],[-0.25,-0.25]],"v":[[30,-72.948],[15.5,-73.948],[5.25,-61.698],[30.523,35.599],[44.773,45.599],[61.273,35.349],[45.5,-45.948]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":30,"s":[{"i":[[9.5,3.948],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-1.278,4.408],[0.25,0.25]],"o":[[-7.971,-3.312],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[3.727,-12.849],[-0.25,-0.25]],"v":[[30,-72.948],[15.5,-73.948],[5.25,-61.698],[30.523,35.599],[44.773,45.599],[61.273,35.349],[45.5,-45.948]],"c":true}]},{"t":43,"s":[{"i":[[9.888,1.745],[0,0],[1.5,-10.5],[-3.25,-6.75],[-10.75,-1],[-2.25,4],[0.25,0.25]],"o":[[-8.5,-1.5],[0,0],[-1.5,10.5],[3.25,6.75],[10.75,1],[2.25,-4],[-0.25,-0.25]],"v":[[30,-130.75],[17,-130.25],[6.75,-118],[8,-67.75],[22.25,-57.75],[38.75,-68],[40.5,-116.25]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.2901960784313726,0.5647058823529412,0.8862745098039215,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":80,"st":0,"bm":0},{"ddd":0,"ind":4,"ty":4,"nm":"Middle_finger","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[256,256,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[9.375,-1.616],[0,0],[-1.75,-10.75],[-1.25,-4.25],[-8.75,-0.5],[1,13],[3,5]],"o":[[-7.25,1.25],[0,0],[1.75,10.75],[1.25,4.25],[8.75,0.5],[-1,-13],[-3,-5]],"v":[[-24.5,-140.75],[-36,-130.75],[-35.5,-117.5],[-28,-74.5],[-15,-61],[5.5,-75.25],[-5.25,-132.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[9.375,-1.616],[0,0],[-1.75,-10.75],[-1.25,-4.25],[-8.75,-0.5],[1,13],[3,5]],"o":[[-7.25,1.25],[0,0],[1.75,10.75],[1.25,4.25],[8.75,0.5],[-1,-13],[-3,-5]],"v":[[-23.25,-115.75],[-34.75,-105.75],[-34.25,-92.5],[-20.5,-34.5],[-7.5,-21],[13,-35.25],[-4,-107.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":22,"s":[{"i":[[11.347,-1.939],[0,0],[-1.576,-9.505],[-1.513,-5.149],[-10.587,-0.606],[4.501,20.379],[3.63,6.058]],"o":[[-14.136,2.416],[0,0],[2.159,13.018],[1.512,5.149],[10.587,0.606],[-3.407,-15.426],[-3.63,-6.058]],"v":[[-19.572,-73.033],[-33.863,-59.542],[-32.383,-43.737],[-11.62,23.537],[5.985,48.019],[25.79,24.003],[1.47,-60.859]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":28,"s":[{"i":[[11.347,-1.939],[0,0],[-1.576,-9.505],[-1.513,-5.149],[-10.587,-0.606],[4.501,20.379],[3.63,6.058]],"o":[[-14.136,2.416],[0,0],[2.159,13.018],[1.512,5.149],[10.587,0.606],[-3.407,-15.426],[-3.63,-6.058]],"v":[[-19.572,-73.033],[-33.863,-59.542],[-32.383,-43.737],[-11.62,23.537],[5.985,48.019],[25.79,24.003],[1.47,-60.859]],"c":true}]},{"t":43,"s":[{"i":[[9.375,-1.616],[0,0],[-1.75,-10.75],[-1.25,-4.25],[-8.75,-0.5],[1,13],[3,5]],"o":[[-7.25,1.25],[0,0],[1.75,10.75],[1.25,4.25],[8.75,0.5],[-1,-13],[-3,-5]],"v":[[-24.5,-140.75],[-36,-130.75],[-35.5,-117.5],[-28,-74.5],[-15,-61],[5.5,-75.25],[-5.25,-132.25]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.419607877731,0,0.454901993275,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[-0.916,-1.008],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 3","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[6.983,-0.66],[-3.834,-11.242],[-1.839,-8.422],[-0.584,-7.242],[-3.51,0.965],[0.266,4.988],[8.051,17.579]],"o":[[-9.334,0.883],[3.796,11.131],[2.338,10.709],[1.03,12.774],[4.816,-1.324],[-1.031,-19.307],[-2.921,-6.377]],"v":[[-24.5,-140.75],[-14.25,-125.75],[-8.75,-101.375],[-4,-74.5],[-1.875,-62.75],[5.5,-75.25],[-5.25,-132.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[-2.412,-1.507],[-2.855,-11.53],[-1.839,-8.422],[-0.584,-7.242],[-3.612,0.453],[0.266,4.988],[6.572,18.184]],"o":[[6.416,4.008],[2.416,9.758],[2.338,10.709],[1.03,12.774],[6.416,-0.805],[-1.031,-19.307],[-4.334,-11.992]],"v":[[-23,-114.75],[-6.25,-84.5],[-0.75,-60.125],[4,-33.25],[2.375,-21.25],[13.5,-34],[-3.75,-106.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":22,"s":[{"i":[[-2.412,-1.507],[-2.855,-11.53],[-1.839,-8.422],[-0.584,-7.242],[-3.612,0.453],[0.266,4.988],[6.572,18.184]],"o":[[6.416,4.008],[2.416,9.758],[2.338,10.709],[1.03,12.774],[6.416,-0.805],[-1.031,-19.307],[-4.334,-11.992]],"v":[[-22,-72.5],[-2.75,-41.75],[5,-15.125],[16,34],[14.375,46],[25.5,33.25],[-0.25,-63.5]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":28,"s":[{"i":[[-2.412,-1.507],[-2.855,-11.53],[-1.839,-8.422],[-0.584,-7.242],[-3.612,0.453],[0.266,4.988],[6.572,18.184]],"o":[[6.416,4.008],[2.416,9.758],[2.338,10.709],[1.03,12.774],[6.416,-0.805],[-1.031,-19.307],[-4.334,-11.992]],"v":[[-22,-72.5],[-2.75,-41.75],[5,-15.125],[16,34],[14.375,46],[25.5,33.25],[-0.25,-63.5]],"c":true}]},{"t":43,"s":[{"i":[[6.983,-0.66],[-3.834,-11.242],[-1.839,-8.422],[-0.584,-7.242],[-3.51,0.965],[0.266,4.988],[8.051,17.579]],"o":[[-9.334,0.883],[3.796,11.131],[2.338,10.709],[1.03,12.774],[4.816,-1.324],[-1.031,-19.307],[-2.921,-6.377]],"v":[[-24.5,-140.75],[-14.25,-125.75],[-8.75,-101.375],[-4,-74.5],[-1.875,-62.75],[5.5,-75.25],[-5.25,-132.25]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.050980392156862744,0.4627450980392157,0.9450980392156862,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[-0.916,-1.008],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 2","np":3,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[9.375,-1.616],[0,0],[-1.75,-10.75],[-1.25,-4.25],[-8.75,-0.5],[1,13],[3,5]],"o":[[-7.25,1.25],[0,0],[1.75,10.75],[1.25,4.25],[8.75,0.5],[-1,-13],[-3,-5]],"v":[[-24.5,-140.75],[-36,-130.75],[-35.5,-117.5],[-28,-74.5],[-15,-61],[5.5,-75.25],[-5.25,-132.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[9.375,-1.616],[0,0],[-1.75,-10.75],[-1.25,-4.25],[-8.75,-0.5],[1,13],[3,5]],"o":[[-7.25,1.25],[0,0],[1.75,10.75],[1.25,4.25],[8.75,0.5],[-1,-13],[-3,-5]],"v":[[-23.25,-115.75],[-34.75,-105.75],[-34.25,-92.5],[-20.5,-34.5],[-7.5,-21],[13,-35.25],[-4,-107.25]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":22,"s":[{"i":[[11.347,-1.939],[0,0],[-1.576,-9.505],[-1.513,-5.149],[-10.587,-0.606],[4.501,20.379],[3.63,6.058]],"o":[[-14.136,2.416],[0,0],[2.159,13.018],[1.512,5.149],[10.587,0.606],[-3.407,-15.426],[-3.63,-6.058]],"v":[[-19.572,-73.033],[-33.863,-59.542],[-32.383,-43.737],[-11.62,23.537],[5.985,48.019],[25.79,24.003],[1.47,-60.859]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":28,"s":[{"i":[[11.347,-1.939],[0,0],[-1.576,-9.505],[-1.513,-5.149],[-10.587,-0.606],[4.501,20.379],[3.63,6.058]],"o":[[-14.136,2.416],[0,0],[2.159,13.018],[1.512,5.149],[10.587,0.606],[-3.407,-15.426],[-3.63,-6.058]],"v":[[-19.572,-73.033],[-33.863,-59.542],[-32.383,-43.737],[-11.62,23.537],[5.985,48.019],[25.79,24.003],[1.47,-60.859]],"c":true}]},{"t":43,"s":[{"i":[[9.375,-1.616],[0,0],[-1.75,-10.75],[-1.25,-4.25],[-8.75,-0.5],[1,13],[3,5]],"o":[[-7.25,1.25],[0,0],[1.75,10.75],[1.25,4.25],[8.75,0.5],[-1,-13],[-3,-5]],"v":[[-24.5,-140.75],[-36,-130.75],[-35.5,-117.5],[-28,-74.5],[-15,-61],[5.5,-75.25],[-5.25,-132.25]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.2901960784313726,0.5647058823529412,0.8862745098039215,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[-0.916,-1.008],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":80,"st":0,"bm":0},{"ddd":0,"ind":5,"ty":4,"nm":"Ring_finger","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[256,256,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[10,1],[0.392,-5.492],[-3.5,-9.25],[-7.75,-2.75],[4.636,19.412],[1,3.5]],"o":[[-10,-1],[-0.5,7],[6.128,16.195],[7.75,2.75],[-4,-16.75],[-1,-3.5]],"v":[[-55.5,-105],[-75.5,-93],[-71.5,-73.5],[-50,-28.5],[-26.75,-48],[-39.75,-87]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[11.181,1.09],[0.439,-5.987],[-3.913,-10.085],[-12.321,-5.496],[6.183,21.764],[1.118,3.816]],"o":[[-11.181,-1.09],[-0.559,7.632],[6.851,17.656],[9.694,4.324],[-5.138,-18.086],[-1.118,-3.816]],"v":[[-51.579,-63.91],[-73.941,-50.826],[-69.469,-29.566],[-34.429,44.746],[-12.683,21.736],[-33.969,-44.285]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[11.181,1.09],[0.439,-5.987],[-3.913,-10.085],[-12.321,-5.496],[6.183,21.764],[1.118,3.816]],"o":[[-11.181,-1.09],[-0.559,7.632],[6.851,17.656],[9.694,4.324],[-5.138,-18.086],[-1.118,-3.816]],"v":[[-51.579,-63.91],[-73.941,-50.826],[-69.469,-29.566],[-34.429,44.746],[-12.683,21.736],[-33.969,-44.285]],"c":true}]},{"t":36,"s":[{"i":[[10,1],[0.392,-5.492],[-3.5,-9.25],[-7.75,-2.75],[4.636,19.412],[1,3.5]],"o":[[-10,-1],[-0.5,7],[6.128,16.195],[7.75,2.75],[-4,-16.75],[-1,-3.5]],"v":[[-55.5,-105],[-75.5,-93],[-71.5,-73.5],[-50,-28.5],[-26.75,-48],[-39.75,-87]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.419607877731,0,0.454901993275,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 3","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[10.047,0.251],[-3.5,-2.25],[-3.5,-9.25],[5.75,-8.625],[4,14.875],[1,3.5]],"o":[[-5,-0.125],[10.073,6.476],[6.128,16.195],[-1.746,2.619],[-4.472,-16.63],[-1,-3.5]],"v":[[-55.5,-105],[-63.375,-102.125],[-47,-75.5],[-39.25,-28.625],[-26.75,-48],[-39.75,-87]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[10.047,0.251],[-3.811,-1.67],[-4.52,-8.796],[5.75,-8.625],[1.619,9.628],[1,3.5]],"o":[[-5,-0.125],[11.125,4.875],[9.25,18],[-1.746,2.619],[-4.75,-28.25],[-1,-3.5]],"v":[[-52.5,-63.75],[-60.375,-60.875],[-43.25,-40.25],[-22.75,43.625],[-11.5,30.25],[-36,-51.75]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[10.047,0.251],[-3.811,-1.67],[-4.52,-8.796],[5.75,-8.625],[1.619,9.628],[1,3.5]],"o":[[-5,-0.125],[11.125,4.875],[9.25,18],[-1.746,2.619],[-4.75,-28.25],[-1,-3.5]],"v":[[-52.5,-63.75],[-60.375,-60.875],[-43.25,-40.25],[-22.75,43.625],[-11.5,30.25],[-36,-51.75]],"c":true}]},{"t":36,"s":[{"i":[[10.047,0.251],[-3.5,-2.25],[-3.5,-9.25],[5.75,-8.625],[4,14.875],[1,3.5]],"o":[[-5,-0.125],[10.073,6.476],[6.128,16.195],[-1.746,2.619],[-4.472,-16.63],[-1,-3.5]],"v":[[-55.5,-105],[-63.375,-102.125],[-47,-75.5],[-39.25,-28.625],[-26.75,-48],[-39.75,-87]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.050980392156862744,0.4627450980392157,0.9450980392156862,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 2","np":3,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[10,1],[0.392,-5.492],[-3.5,-9.25],[-7.75,-2.75],[4.636,19.412],[1,3.5]],"o":[[-10,-1],[-0.5,7],[6.128,16.195],[7.75,2.75],[-4,-16.75],[-1,-3.5]],"v":[[-55.5,-105],[-75.5,-93],[-71.5,-73.5],[-50,-28.5],[-26.75,-48],[-39.75,-87]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[11.181,1.09],[0.439,-5.987],[-3.913,-10.085],[-12.321,-5.496],[6.183,21.764],[1.118,3.816]],"o":[[-11.181,-1.09],[-0.559,7.632],[6.851,17.656],[9.694,4.324],[-5.138,-18.086],[-1.118,-3.816]],"v":[[-51.579,-63.91],[-73.941,-50.826],[-69.469,-29.566],[-34.429,44.746],[-12.683,21.736],[-33.969,-44.285]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[11.181,1.09],[0.439,-5.987],[-3.913,-10.085],[-12.321,-5.496],[6.183,21.764],[1.118,3.816]],"o":[[-11.181,-1.09],[-0.559,7.632],[6.851,17.656],[9.694,4.324],[-5.138,-18.086],[-1.118,-3.816]],"v":[[-51.579,-63.91],[-73.941,-50.826],[-69.469,-29.566],[-34.429,44.746],[-12.683,21.736],[-33.969,-44.285]],"c":true}]},{"t":36,"s":[{"i":[[10,1],[0.392,-5.492],[-3.5,-9.25],[-7.75,-2.75],[4.636,19.412],[1,3.5]],"o":[[-10,-1],[-0.5,7],[6.128,16.195],[7.75,2.75],[-4,-16.75],[-1,-3.5]],"v":[[-55.5,-105],[-75.5,-93],[-71.5,-73.5],[-50,-28.5],[-26.75,-48],[-39.75,-87]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.2901960784313726,0.5647058823529412,0.8862745098039215,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":80,"st":0,"bm":0},{"ddd":0,"ind":6,"ty":4,"nm":"little_finger","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[256,256,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[0,0],[8.75,-4.25],[1.75,-2.75],[-1.75,-7],[-5.439,-6.744],[-6.59,4.43],[-0.318,6.593],[4.5,12.75]],"o":[[0,0],[-8.75,4.25],[-1.75,2.75],[1.75,7],[4.264,5.288],[3.069,-2.063],[0,-0.5],[0.25,0.5]],"v":[[-67.375,-49.125],[-86.75,-54.75],[-98.25,-44.5],[-99.25,-25],[-83.5,9.5],[-62.097,14.598],[-56.5,2],[-66.75,-32.5]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[0,0],[7.796,-3.39],[1.75,-2.75],[-1.35,-7.088],[-2.25,-5],[-14.172,1.542],[1.375,10.625],[14.25,29.75]],"o":[[0,0],[-8.625,3.75],[-1.75,2.75],[3,15.75],[6.765,15.033],[4.691,-0.51],[0,-0.5],[0.25,0.5]],"v":[[-70.375,-33.875],[-85.5,-37.25],[-96.75,-27],[-97.75,-7.5],[-86.75,21.75],[-56.328,49.583],[-48.875,31.5],[-63.75,-12.75]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[0,0],[7.796,-3.39],[1.75,-2.75],[-1.35,-7.088],[-2.25,-5],[-14.172,1.542],[1.375,10.625],[14.25,29.75]],"o":[[0,0],[-8.625,3.75],[-1.75,2.75],[3,15.75],[6.765,15.033],[4.691,-0.51],[0,-0.5],[0.25,0.5]],"v":[[-70.375,-33.875],[-85.5,-37.25],[-96.75,-27],[-97.75,-7.5],[-86.75,21.75],[-56.328,49.583],[-48.875,31.5],[-63.75,-12.75]],"c":false}]},{"t":43,"s":[{"i":[[0,0],[8.75,-4.25],[1.75,-2.75],[-1.75,-7],[-5.439,-6.744],[-6.59,4.43],[-0.318,6.593],[4.5,12.75]],"o":[[0,0],[-8.75,4.25],[-1.75,2.75],[1.75,7],[4.264,5.288],[3.069,-2.063],[0,-0.5],[0.25,0.5]],"v":[[-67.375,-49.125],[-86.75,-54.75],[-98.25,-44.5],[-99.25,-25],[-83.5,9.5],[-62.097,14.598],[-56.5,2],[-66.75,-32.5]],"c":false}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.419607877731,0,0.454901993275,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 3","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[0,0],[4,1.5],[1.75,-2.75],[-1.75,-7],[-5.439,-6.744],[-1.028,3.652],[0.778,4.964],[2.806,7.435]],"o":[[0,0],[-3.511,-1.317],[-1.75,2.75],[1.75,7],[4.264,5.288],[1.126,-4.002],[-1.832,-11.695],[0,0]],"v":[[-66.375,-48.625],[-75.25,-53.5],[-82.75,-46.5],[-83.75,-26.75],[-66.125,7.375],[-57.472,10.348],[-57.125,-1.625],[-65.625,-35.625]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[0,0],[4,1.5],[1.75,-2.75],[-1.75,-7],[-5.439,-6.744],[-1.028,3.652],[0.778,4.964],[2.806,7.435]],"o":[[0,0],[-3.511,-1.317],[-1.75,2.75],[1.75,7],[4.264,5.288],[1.126,-4.002],[-1.832,-11.695],[0,0]],"v":[[-66.375,-30.125],[-73.5,-35],[-81,-28],[-82,-8.25],[-58.875,40.875],[-50.222,43.848],[-49.875,31.875],[-65.625,-17.125]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[0,0],[4,1.5],[1.75,-2.75],[-1.75,-7],[-5.439,-6.744],[-1.028,3.652],[0.778,4.964],[2.806,7.435]],"o":[[0,0],[-3.511,-1.317],[-1.75,2.75],[1.75,7],[4.264,5.288],[1.126,-4.002],[-1.832,-11.695],[0,0]],"v":[[-66.375,-30.125],[-73.5,-35],[-81,-28],[-82,-8.25],[-58.875,40.875],[-50.222,43.848],[-49.875,31.875],[-65.625,-17.125]],"c":false}]},{"t":43,"s":[{"i":[[0,0],[4,1.5],[1.75,-2.75],[-1.75,-7],[-5.439,-6.744],[-1.028,3.652],[0.778,4.964],[2.806,7.435]],"o":[[0,0],[-3.511,-1.317],[-1.75,2.75],[1.75,7],[4.264,5.288],[1.126,-4.002],[-1.832,-11.695],[0,0]],"v":[[-66.375,-48.625],[-75.25,-53.5],[-82.75,-46.5],[-83.75,-26.75],[-66.125,7.375],[-57.472,10.348],[-57.125,-1.625],[-65.625,-35.625]],"c":false}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.050980392156862744,0.4627450980392157,0.9450980392156862,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 2","np":3,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[0,0],[8.75,-4.25],[1.75,-2.75],[-1.75,-7],[-5.439,-6.744],[-6.59,4.43],[-0.318,6.593],[4.5,12.75]],"o":[[0,0],[-8.75,4.25],[-1.75,2.75],[1.75,7],[4.264,5.288],[3.069,-2.063],[0,-0.5],[0.25,0.5]],"v":[[-67.375,-49.125],[-86.75,-54.75],[-98.25,-44.5],[-99.25,-25],[-83.5,9.5],[-62.097,14.598],[-56.5,2],[-66.75,-32.5]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[0,0],[7.796,-3.39],[1.75,-2.75],[-1.35,-7.088],[-2.25,-5],[-14.172,1.542],[1.375,10.625],[14.25,29.75]],"o":[[0,0],[-8.625,3.75],[-1.75,2.75],[3,15.75],[6.765,15.033],[4.691,-0.51],[0,-0.5],[0.25,0.5]],"v":[[-70.375,-33.875],[-85.5,-37.25],[-96.75,-27],[-97.75,-7.5],[-86.75,21.75],[-56.328,49.583],[-48.875,31.5],[-63.75,-12.75]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[0,0],[7.796,-3.39],[1.75,-2.75],[-1.35,-7.088],[-2.25,-5],[-14.172,1.542],[1.375,10.625],[14.25,29.75]],"o":[[0,0],[-8.625,3.75],[-1.75,2.75],[3,15.75],[6.765,15.033],[4.691,-0.51],[0,-0.5],[0.25,0.5]],"v":[[-70.375,-33.875],[-85.5,-37.25],[-96.75,-27],[-97.75,-7.5],[-86.75,21.75],[-56.328,49.583],[-48.875,31.5],[-63.75,-12.75]],"c":false}]},{"t":43,"s":[{"i":[[0,0],[8.75,-4.25],[1.75,-2.75],[-1.75,-7],[-5.439,-6.744],[-6.59,4.43],[-0.318,6.593],[4.5,12.75]],"o":[[0,0],[-8.75,4.25],[-1.75,2.75],[1.75,7],[4.264,5.288],[3.069,-2.063],[0,-0.5],[0.25,0.5]],"v":[[-67.375,-49.125],[-86.75,-54.75],[-98.25,-44.5],[-99.25,-25],[-83.5,9.5],[-62.097,14.598],[-56.5,2],[-66.75,-32.5]],"c":false}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.2901960784313726,0.5647058823529412,0.8862745098039215,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":80,"st":0,"bm":0},{"ddd":0,"ind":7,"ty":4,"nm":"Hand/Thump","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[256,256,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[0,0],[-6.5,-9.5],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[6.25,2.25],[0,0],[0.75,5],[3.75,5.5],[26,-13.5],[0.5,-1],[-23.5,-54.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[6.5,9.5],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-6.25,-2.25],[0,0],[-0.75,-5],[-3.75,-5.5],[-26,13.5],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.75,-1],[62.75,22],[90,37.75],[112.75,24.25],[96.25,-1.5],[59.5,-13.25],[42.5,-20],[35.25,-32],[28.875,-57.125],[-33.5,-72.5],[-68.5,-50.25],[-74.5,22],[-55,41],[-5,34],[39.25,32.5],[55.625,20.812],[52.375,20.812],[62.188,21.062]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[0,0],[-6.859,-11.174],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[6.005,2.775],[0,0],[1.826,5.12],[4.682,4.515],[26.076,-10.152],[0.5,-1],[-23.5,-54.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[6.073,9.765],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-4.696,-2.011],[0,0],[-1.591,-4.708],[-8.592,-6.875],[-29.924,14.848],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.511,-1.239],[61.315,22.837],[89.761,39.902],[110.478,25.565],[96.37,0.772],[55.315,-16.239],[44.533,-22.63],[39.12,-33.315],[28.538,-57.049],[-23.076,-62.848],[-67.957,-41.033],[-74.5,22],[-55,41],[-2.13,31.37],[39.25,32.5],[55.266,20.932],[52.375,20.812],[60.035,20.823]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":23,"s":[{"i":[[0,0],[-7.25,-13],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[5.738,3.347],[0,0],[3,5.25],[5.699,3.44],[22.088,-10.756],[0.5,-1],[-18.5,-44.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[5.607,10.053],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-3,-1.75],[0,0],[-2.508,-4.39],[-13.875,-8.375],[-28.75,14],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.25,-1.5],[59.75,23.75],[89.5,42.25],[108,27],[96.5,3.25],[50.75,-19.5],[46.75,-25.5],[41.25,-34.75],[27.125,-54.875],[-24.25,-56.5],[-70,-32.75],[-74.5,22],[-55,41],[1,28.5],[39.25,32.5],[54.875,21.062],[52.375,20.812],[57.688,20.562]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[0,0],[-7.25,-13],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[5.738,3.347],[0,0],[3,5.25],[5.699,3.44],[22.088,-10.756],[0.5,-1],[-18.5,-44.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[5.607,10.053],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-3,-1.75],[0,0],[-2.508,-4.39],[-13.875,-8.375],[-28.75,14],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.25,-1.5],[59.75,23.75],[89.5,42.25],[108,27],[96.5,3.25],[50.75,-19.5],[46.75,-25.5],[41.25,-34.75],[27.125,-54.875],[-24.25,-56.5],[-70,-32.75],[-74.5,22],[-55,41],[1,28.5],[39.25,32.5],[54.875,21.062],[52.375,20.812],[57.688,20.562]],"c":false}]},{"t":43,"s":[{"i":[[0,0],[-6.5,-9.5],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[6.25,2.25],[0,0],[0.75,5],[3.75,5.5],[26,-13.5],[0.5,-1],[-23.5,-54.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[6.5,9.5],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-6.25,-2.25],[0,0],[-0.75,-5],[-3.75,-5.5],[-26,13.5],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.75,-1],[62.75,22],[90,37.75],[112.75,24.25],[96.25,-1.5],[59.5,-13.25],[42.5,-20],[35.25,-32],[28.875,-57.125],[-33.5,-72.5],[-68.5,-50.25],[-74.5,22],[-55,41],[-5,34],[39.25,32.5],[55.625,20.812],[52.375,20.812],[62.188,21.062]],"c":false}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.419607877731,0,0.454901993275,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":2,"lj":2,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 3","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[26,-13.5],[0.5,-1],[-9.671,-39.373],[0,0],[-1.542,-3.576],[-12,-3],[-16,10],[-12.328,3.216],[0,0],[-2,0.312],[0,0],[0,0],[-7.625,-15.875],[-3,0.5],[-0.375,9.125],[8.75,3.5],[6.25,2.25],[0,0],[0.75,5],[3.75,5.5]],"o":[[-26,13.5],[-0.217,-0.217],[0.722,2.939],[0,0],[1,1.5],[12,3],[0.75,-0.5],[5.75,-1.5],[0,0],[-1.5,-11.562],[0,0],[0,0],[6.658,13.861],[4.378,-0.73],[0.6,-14.593],[-8.75,-3.5],[-6.25,-2.25],[0,0],[-0.75,-5],[-3.75,-5.5]],"v":[[-33.5,-72.5],[-60.25,-56.75],[-72.938,-4.015],[-35.467,-18.261],[-66.25,15.5],[-46.75,34.5],[3.5,28],[47.75,26.5],[55.625,20.812],[61.125,20.812],[67.062,0.562],[69.25,-1.5],[102.5,16],[99.5,38.25],[112.75,24.25],[96.25,-1.5],[59.5,-13.25],[42.5,-20],[35.25,-32],[28.875,-57.125]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[31,-14.75],[7.25,-6.25],[-2.812,-16.485],[0,0],[-1.542,-3.576],[-12,-3],[-16,10],[-14,1.75],[0,0],[-2,0.312],[0,0],[0,0],[-7.625,-15.875],[-3,0.5],[-0.375,9.125],[8.75,3.5],[6.25,2.25],[0,0],[2.5,6],[3.75,5.5]],"o":[[-31.818,15.139],[-3,5.25],[0.501,2.985],[0,0],[1,1.5],[12,3],[0.75,-0.5],[5.897,-0.737],[0,0],[-2.375,-12.312],[0,0],[0,0],[6.658,13.861],[4.378,-0.73],[0.6,-14.593],[-8.75,-3.5],[-6.25,-2.25],[0,0],[-1.945,-4.667],[-3.75,-5.5]],"v":[[-29.25,-60.25],[-71.375,-37.625],[-72.938,-4.015],[-35.467,-18.261],[-66.25,15.5],[-46.75,34.5],[7.75,24.25],[42.5,27],[52.125,20.312],[59.125,19.812],[67.062,0.562],[69.25,-1.5],[99.25,15.25],[98.5,40.5],[110.25,26.5],[97.75,2.75],[61.75,-12.75],[47.25,-20.25],[38.75,-35],[28.875,-57.125]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":23,"s":[{"i":[[31.75,-16.75],[5.25,-7.25],[-2.812,-16.485],[0,0],[-1.542,-3.576],[-12,-3],[-16,10],[-14,1.75],[0,0],[-2,0.312],[0,0],[0,0],[-2.979,-7.172],[-2.964,0.684],[-0.375,9.125],[8.75,3.5],[6.375,3.75],[0,0],[2.375,4.125],[3.75,5.5]],"o":[[-31.165,16.441],[-3,5.25],[0.501,2.985],[0,0],[1,1.5],[12,3],[0.75,-0.5],[5.897,-0.737],[0,0],[-2.375,-12.312],[0,0],[0,0],[6.75,16.25],[6.5,-1.5],[0.6,-14.593],[-8.75,-3.5],[-5.726,-3.368],[0,0],[-2.523,-4.382],[-3.75,-5.5]],"v":[[-22.75,-57.25],[-64,-28.75],[-65.938,4.485],[-28.467,-9.761],[-59.25,24],[-46.75,34.5],[7.75,24.25],[42.5,27],[52.125,20.312],[59.125,19.812],[67.062,0.562],[69.25,-1.5],[96.25,15],[98.5,40.5],[108.5,23.25],[88.25,-1.25],[58.75,-15.125],[51.75,-18.625],[45.75,-26.5],[34.125,-47.375]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[31.75,-16.75],[5.25,-7.25],[-2.812,-16.485],[0,0],[-1.542,-3.576],[-12,-3],[-16,10],[-14,1.75],[0,0],[-2,0.312],[0,0],[0,0],[-2.979,-7.172],[-2.964,0.684],[-0.375,9.125],[8.75,3.5],[6.375,3.75],[0,0],[2.375,4.125],[3.75,5.5]],"o":[[-31.165,16.441],[-3,5.25],[0.501,2.985],[0,0],[1,1.5],[12,3],[0.75,-0.5],[5.897,-0.737],[0,0],[-2.375,-12.312],[0,0],[0,0],[6.75,16.25],[6.5,-1.5],[0.6,-14.593],[-8.75,-3.5],[-5.726,-3.368],[0,0],[-2.523,-4.382],[-3.75,-5.5]],"v":[[-22.75,-57.25],[-64,-28.75],[-65.938,4.485],[-28.467,-9.761],[-59.25,24],[-46.75,34.5],[7.75,24.25],[42.5,27],[52.125,20.312],[59.125,19.812],[67.062,0.562],[69.25,-1.5],[96.25,15],[98.5,40.5],[108.5,23.25],[88.25,-1.25],[58.75,-15.125],[51.75,-18.625],[45.75,-26.5],[34.125,-47.375]],"c":true}]},{"t":43,"s":[{"i":[[26,-13.5],[0.5,-1],[-25.062,-31.735],[0,0],[-1.542,-3.576],[-12,-3],[-16,10],[-12.328,3.216],[0,0],[-2,0.312],[0,0],[0,0],[-7.625,-15.875],[-3,0.5],[-0.375,9.125],[8.75,3.5],[6.25,2.25],[0,0],[0.75,5],[3.75,5.5]],"o":[[-26,13.5],[-0.217,-0.217],[1.876,2.375],[0,0],[1,1.5],[12,3],[0.75,-0.5],[5.75,-1.5],[0,0],[-1.5,-11.562],[0,0],[0,0],[6.658,13.861],[4.378,-0.73],[0.6,-14.593],[-8.75,-3.5],[-6.25,-2.25],[0,0],[-0.75,-5],[-3.75,-5.5]],"v":[[-33.5,-72.5],[-59,-57.5],[-72.938,-4.015],[-35.467,-18.261],[-66.25,15.5],[-46.75,34.5],[3.5,28],[47.75,26.5],[55.625,20.812],[61.125,20.812],[67.062,0.562],[69.25,-1.5],[102.5,16],[99.5,38.25],[112.75,24.25],[96.25,-1.5],[59.5,-13.25],[42.5,-20],[35.25,-32],[28.875,-57.125]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.050980392156862744,0.4627450980392157,0.9450980392156862,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 2","np":3,"cix":2,"bm":0,"ix":2,"mn":"ADBE Vector Group","hd":false},{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[0,0],[-6.5,-9.5],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[6.25,2.25],[0,0],[0.75,5],[3.75,5.5],[26,-13.5],[0.5,-1],[-23.5,-54.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[6.5,9.5],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-6.25,-2.25],[0,0],[-0.75,-5],[-3.75,-5.5],[-26,13.5],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.75,-1],[62.75,22],[90,37.75],[112.75,24.25],[96.25,-1.5],[59.5,-13.25],[42.5,-20],[35.25,-32],[28.875,-57.125],[-33.5,-72.5],[-68.5,-50.25],[-74.5,22],[-55,41],[-5,34],[39.25,32.5],[55.625,20.812],[52.375,20.812],[62.188,21.062]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[0,0],[-6.859,-11.174],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[6.005,2.775],[0,0],[1.826,5.12],[4.682,4.515],[26.076,-10.152],[0.5,-1],[-23.5,-54.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[6.073,9.765],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-4.696,-2.011],[0,0],[-1.591,-4.708],[-8.592,-6.875],[-29.924,14.848],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.511,-1.239],[61.315,22.837],[89.761,39.902],[110.478,25.565],[96.37,0.772],[55.315,-16.239],[44.533,-22.63],[39.12,-33.315],[28.538,-57.049],[-23.076,-62.848],[-67.957,-41.033],[-74.5,22],[-55,41],[-2.13,31.37],[39.25,32.5],[55.266,20.932],[52.375,20.812],[60.035,20.823]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":23,"s":[{"i":[[0,0],[-7.25,-13],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[5.738,3.347],[0,0],[3,5.25],[5.699,3.44],[22.088,-10.756],[0.5,-1],[-18.5,-44.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[5.607,10.053],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-3,-1.75],[0,0],[-2.508,-4.39],[-13.875,-8.375],[-28.75,14],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.25,-1.5],[59.75,23.75],[89.5,42.25],[108,27],[96.5,3.25],[50.75,-19.5],[46.75,-25.5],[41.25,-34.75],[27.125,-54.875],[-24.25,-56.5],[-70,-32.75],[-74.5,22],[-55,41],[1,28.5],[39.25,32.5],[54.875,21.062],[52.375,20.812],[57.688,20.562]],"c":false}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[0,0],[-7.25,-13],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[5.738,3.347],[0,0],[3,5.25],[5.699,3.44],[22.088,-10.756],[0.5,-1],[-18.5,-44.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[5.607,10.053],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-3,-1.75],[0,0],[-2.508,-4.39],[-13.875,-8.375],[-28.75,14],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.25,-1.5],[59.75,23.75],[89.5,42.25],[108,27],[96.5,3.25],[50.75,-19.5],[46.75,-25.5],[41.25,-34.75],[27.125,-54.875],[-24.25,-56.5],[-70,-32.75],[-74.5,22],[-55,41],[1,28.5],[39.25,32.5],[54.875,21.062],[52.375,20.812],[57.688,20.562]],"c":false}]},{"t":43,"s":[{"i":[[0,0],[-6.5,-9.5],[-9,-0.75],[-1.75,14.5],[8.75,3.5],[6.25,2.25],[0,0],[0.75,5],[3.75,5.5],[26,-13.5],[0.5,-1],[-23.5,-54.5],[-12,-3],[-16,10],[-12.25,3.5],[0,0],[0,0],[0,0]],"o":[[0,0],[6.5,9.5],[9,0.75],[1.75,-14.5],[-8.75,-3.5],[-6.25,-2.25],[0,0],[-0.75,-5],[-3.75,-5.5],[-26,13.5],[-0.25,-0.25],[1,1.5],[12,3],[0.75,-0.5],[12.25,-3.5],[0,0],[0,0],[0,0]],"v":[[68.75,-1],[62.75,22],[90,37.75],[112.75,24.25],[96.25,-1.5],[59.5,-13.25],[42.5,-20],[35.25,-32],[28.875,-57.125],[-33.5,-72.5],[-68.5,-50.25],[-74.5,22],[-55,41],[-5,34],[39.25,32.5],[55.625,20.812],[52.375,20.812],[62.188,21.062]],"c":false}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.2901960784313726,0.5647058823529412,0.8862745098039215,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":3,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":80,"st":0,"bm":0},{"ddd":0,"ind":8,"ty":4,"nm":"shadow","sr":1,"ks":{"o":{"a":0,"k":50,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[256,256,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[95.5,4],[0,0],[-23.75,-2.25],[-23.5,1.25],[-5.25,3.25],[-5.36,-0.133],[-5.702,-0.129],[-6.5,-0.112],[-4.237,-0.051],[-11.143,5.65]],"o":[[-95.5,-4],[0,0],[0,-0.25],[0.25,0],[3.873,0.082],[4.819,0.119],[5.886,0.133],[4.1,0.07],[41.645,0.503],[0,-0.25]],"v":[[34.75,34.5],[-64,36.5],[-74,42.25],[-53.5,48.5],[-43.5,45.25],[-29.547,45.582],[-13.689,45.962],[4.972,46.338],[17.498,46.522],[116.5,40.75]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11,"s":[{"i":[[75.5,3],[0,0],[-23.75,-2.25],[-23.5,1.25],[-0.75,5.25],[-6.787,-0.863],[-3.249,1.461],[-5.611,-0.094],[-3.459,-0.044],[-11.254,5.706]],"o":[[-95.508,-3.795],[0,0],[0,-0.25],[0.25,0],[4.708,0.099],[8.492,1.08],[4.732,-2.128],[3.368,0.057],[41.965,0.53],[0,-0.25]],"v":[[51.5,35.25],[-64,36.5],[-74,42.25],[-52.25,51],[-43.5,45.25],[-25.492,50.17],[-10.251,46.039],[5.998,46.855],[16.25,46.507],[116.5,40.75]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":23,"s":[{"i":[[75.5,3],[0,0],[-23.75,-2.25],[-23.5,1.25],[-0.75,5.25],[-6.787,-0.863],[-3.249,1.461],[-5.577,-0.624],[-3.75,1.243],[-11.254,5.706]],"o":[[-95.508,-3.795],[0,0],[0,-0.25],[0.25,0],[4.708,0.099],[8.492,1.08],[4.732,-2.128],[8.002,0.895],[42.25,1.493],[0,-0.25]],"v":[[51.5,35.25],[-64,36.5],[-74,42.25],[-52.25,51],[-43.5,45.25],[-25.492,50.17],[-10.251,46.039],[0.748,49.855],[18.75,46.757],[116.5,40.75]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[{"i":[[75.5,3],[0,0],[-23.75,-2.25],[-23.5,1.25],[-0.75,5.25],[-6.787,-0.863],[-3.249,1.461],[-5.577,-0.624],[-3.75,1.243],[-11.254,5.706]],"o":[[-95.508,-3.795],[0,0],[0,-0.25],[0.25,0],[4.708,0.099],[8.492,1.08],[4.732,-2.128],[8.002,0.895],[42.25,1.493],[0,-0.25]],"v":[[51.5,35.25],[-64,36.5],[-74,42.25],[-52.25,51],[-43.5,45.25],[-25.492,50.17],[-10.251,46.039],[0.748,49.855],[18.75,46.757],[116.5,40.75]],"c":true}]},{"t":43,"s":[{"i":[[95.5,4],[0,0],[-23.75,-2.25],[-23.5,1.25],[-5.25,3.25],[-5.36,-0.133],[-5.702,-0.129],[-6.5,-0.112],[-4.237,-0.051],[-11.143,5.65]],"o":[[-95.5,-4],[0,0],[0,-0.25],[0.25,0],[3.873,0.082],[4.819,0.119],[5.886,0.133],[4.1,0.07],[41.645,0.503],[0,-0.25]],"v":[[34.75,34.5],[-64,36.5],[-74,42.25],[-53.5,48.5],[-43.5,45.25],[-29.547,45.582],[-13.689,45.962],[4.972,46.338],[17.498,46.522],[116.5,40.75]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[0.266666680574,0.266666680574,0.266666680574,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":80,"st":0,"bm":0}],"markers":[]} --------------------------------------------------------------------------------