[
  {
    "path": ".github/workflows/build.yaml",
    "content": "name: Android Build\n\non: [ push ]\n\njobs:\n  build:\n    runs-on: ubuntu-latest\n\n    steps:\n      - name: Checkout code\n        uses: actions/checkout@v2\n\n      - name: Set up JDK 17\n        uses: actions/setup-java@v2\n        with:\n          java-version: 17\n          cache: 'gradle'\n          distribution: adopt\n\n      - name: Build with Gradle\n        run: ./gradlew build\n"
  },
  {
    "path": ".github/workflows/publish.yml",
    "content": "name: Publish\non:\n  push:\n    tags:\n      - '*'\n\njobs:\n  publish:\n    name: Release build and publish\n    runs-on: ubuntu-latest\n    steps:\n      - name: Check out code\n        uses: actions/checkout@v2\n      - name: Set up JDK 17\n        uses: actions/setup-java@v2\n        with:\n          distribution: adopt\n          java-version: 17\n\n      - name: Publish to MavenCentral\n        run: ./gradlew bottombar:publishReleasePublicationToSonatypeRepository --max-workers 1 closeAndReleaseSonatypeStagingRepository\n        env:\n          OSSRH_USERNAME: ${{ secrets.OSSRH_USERNAME }}\n          OSSRH_PASSWORD: ${{ secrets.OSSRH_PASSWORD }}\n          SIGNING_KEY_ID: ${{ secrets.SIGNING_KEY_ID }}\n          SIGNING_PASSWORD: ${{ secrets.SIGNING_PASSWORD }}\n          SIGNING_KEY: ${{ secrets.SIGNING_KEY }}\n          SONATYPE_STAGING_PROFILE_ID: ${{ secrets.SONATYPE_STAGING_PROFILE_ID }}\n          PUBLISH_VERSION: ${{ secrets.PUBLISH_VERSION }}"
  },
  {
    "path": ".gitignore",
    "content": "*.iml\n.gradle\n/local.properties\n/.idea/caches\n/.idea/libraries\n/.idea/modules.xml\n/.idea/workspace.xml\n/.idea/navEditor.xml\n/.idea/assetWizardSettings.xml\n.DS_Store\n/build\n/captures\n.externalNativeBuild\n.cxx\nlocal.properties\n"
  },
  {
    "path": ".idea/.gitignore",
    "content": "# Default ignored files\n/shelf/\n/workspace.xml\n"
  },
  {
    "path": ".idea/.name",
    "content": "AnimatedBottomBarCompose"
  },
  {
    "path": ".idea/compiler.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n  <component name=\"CompilerConfiguration\">\n    <bytecodeTargetLevel target=\"17\" />\n  </component>\n</project>"
  },
  {
    "path": ".idea/deploymentTargetDropDown.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n  <component name=\"deploymentTargetDropDown\">\n    <targetSelectedWithDropDown>\n      <Target>\n        <type value=\"QUICK_BOOT_TARGET\" />\n        <deviceKey>\n          <Key>\n            <type value=\"VIRTUAL_DEVICE_PATH\" />\n            <value value=\"$USER_HOME$/.android/avd/Pixel_3_API_30_-_Play_Store.avd\" />\n          </Key>\n        </deviceKey>\n      </Target>\n    </targetSelectedWithDropDown>\n    <timeTargetWasSelectedWithDropDown value=\"2023-10-24T10:24:17.567125238Z\" />\n  </component>\n</project>"
  },
  {
    "path": ".idea/deploymentTargetSelector.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n  <component name=\"deploymentTargetSelector\">\n    <selectionStates>\n      <SelectionState runConfigName=\"app\">\n        <option name=\"selectionMode\" value=\"DROPDOWN\" />\n        <DropdownSelection timestamp=\"2024-06-07T09:58:35.818321239Z\">\n          <Target type=\"DEFAULT_BOOT\">\n            <handle>\n              <DeviceId pluginId=\"LocalEmulator\" identifier=\"path=/home/meghl/.android/avd/Pixel_3_API_30_-_Play_Store.avd\" />\n            </handle>\n          </Target>\n        </DropdownSelection>\n        <DialogSelection />\n      </SelectionState>\n    </selectionStates>\n  </component>\n</project>"
  },
  {
    "path": ".idea/gradle.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n  <component name=\"GradleMigrationSettings\" migrationVersion=\"1\" />\n  <component name=\"GradleSettings\">\n    <option name=\"linkedExternalProjectsSettings\">\n      <GradleProjectSettings>\n        <option name=\"externalProjectPath\" value=\"$PROJECT_DIR$\" />\n        <option name=\"gradleJvm\" value=\"#GRADLE_LOCAL_JAVA_HOME\" />\n        <option name=\"modules\">\n          <set>\n            <option value=\"$PROJECT_DIR$\" />\n            <option value=\"$PROJECT_DIR$/app\" />\n            <option value=\"$PROJECT_DIR$/bottombar\" />\n          </set>\n        </option>\n        <option name=\"resolveExternalAnnotations\" value=\"false\" />\n      </GradleProjectSettings>\n    </option>\n  </component>\n</project>"
  },
  {
    "path": ".idea/inspectionProfiles/Project_Default.xml",
    "content": "<component name=\"InspectionProjectProfileManager\">\n  <profile version=\"1.0\">\n    <option name=\"myName\" value=\"Project Default\" />\n    <inspection_tool class=\"PreviewAnnotationInFunctionWithParameters\" enabled=\"true\" level=\"ERROR\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n    <inspection_tool class=\"PreviewApiLevelMustBeValid\" enabled=\"true\" level=\"ERROR\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n    <inspection_tool class=\"PreviewDimensionRespectsLimit\" enabled=\"true\" level=\"WARNING\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n    <inspection_tool class=\"PreviewFontScaleMustBeGreaterThanZero\" enabled=\"true\" level=\"ERROR\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n    <inspection_tool class=\"PreviewMultipleParameterProviders\" enabled=\"true\" level=\"ERROR\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n    <inspection_tool class=\"PreviewMustBeTopLevelFunction\" enabled=\"true\" level=\"ERROR\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n    <inspection_tool class=\"PreviewNeedsComposableAnnotation\" enabled=\"true\" level=\"ERROR\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n    <inspection_tool class=\"PreviewNotSupportedInUnitTestFiles\" enabled=\"true\" level=\"ERROR\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n    <inspection_tool class=\"PreviewPickerAnnotation\" enabled=\"true\" level=\"ERROR\" enabled_by_default=\"true\">\n      <option name=\"composableFile\" value=\"true\" />\n      <option name=\"previewFile\" value=\"true\" />\n    </inspection_tool>\n  </profile>\n</component>"
  },
  {
    "path": ".idea/kotlinc.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n  <component name=\"KotlinJpsPluginSettings\">\n    <option name=\"version\" value=\"1.9.10\" />\n  </component>\n</project>"
  },
  {
    "path": ".idea/migrations.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n  <component name=\"ProjectMigrations\">\n    <option name=\"MigrateToGradleLocalJavaHome\">\n      <set>\n        <option value=\"$PROJECT_DIR$\" />\n      </set>\n    </option>\n  </component>\n</project>"
  },
  {
    "path": ".idea/misc.xml",
    "content": "<project version=\"4\">\n  <component name=\"ExternalStorageConfigurationManager\" enabled=\"true\" />\n  <component name=\"ProjectRootManager\" version=\"2\" languageLevel=\"JDK_17\" default=\"true\" project-jdk-name=\"jbr-17\" project-jdk-type=\"JavaSDK\">\n    <output url=\"file://$PROJECT_DIR$/build/classes\" />\n  </component>\n  <component name=\"ProjectType\">\n    <option name=\"id\" value=\"Android\" />\n  </component>\n</project>"
  },
  {
    "path": ".idea/vcs.xml",
    "content": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n  <component name=\"VcsDirectoryMappings\">\n    <mapping directory=\"$PROJECT_DIR$\" vcs=\"Git\" />\n  </component>\n</project>"
  },
  {
    "path": "License",
    "content": "Copyright 2022 Canopas Software LLP\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n   http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n"
  },
  {
    "path": "README.md",
    "content": "<p align=\"center\"> <a href=\"https://canopas.com/contact\"><img src=\"./cta/cta_banner.png\" alt=\"cta_banner\"></a></p>\n\n# AnimatedBottomBarCompose\n\n**AnimatedBottomBarCompose** is a Jetpack Compose library that simplifies the creation of stylish\nBottom Navigation Bars with\ncustomizable animations. It allows you to easily integrate attractive navigation bars into your\nAndroid app, enhancing the user experience.\n<table>\n  <tr>\n    <td align=\"center\">\n       <b>LINE INDICATOR</b>\n       <br />\n       <br />\n      <img src=\"https://github.com/canopas/AnimatedBottomBarCompose/assets/98312779/ed9d5ac1-dc6f-4b91-8c98-e6c8826f4736\"  width=\"80%\" height=\"80%\" alt=\"\">\n    </td>\n    <td align=\"center\">\n       <b>FILLED INDICATOR</b>\n       <br />\n       <br />\n      <img src=\"https://github.com/canopas/AnimatedBottomBarCompose/assets/98312779/75622692-fded-4891-9d32-f2540e8e4744\"  width=\"80%\" height=\"80%\" alt=\"\">\n    </td>\n\n  </tr>\n\n  <tr>\n    <td align=\"center\">\n       <b>DOT INDICATOR</b>\n       <br />\n       <br />\n     <img src=\"https://github.com/canopas/AnimatedBottomBarCompose/assets/98312779/b0dc3420-9c79-4f05-892f-1c67ebea5817\"  width=\"80%\" height=\"80%\" alt=\"\">\n    </td>\n    <td align=\"center\">\n       <b>WORM INDICATOR</b>\n       <br />\n       <br />\n      <img src=\"https://github.com/canopas/AnimatedBottomBarCompose/assets/98312779/8b16d97a-a1c8-40ed-a6be-5fb05fbcd909\"  width=\"80%\" height=\"80%\" alt=\"\">\n    </td>\n</tr>\n</table>\n\n\n## Features\n\n- **Multiple Styles:** Choose from a variety of pre-defined styles for your Bottom Navigation Bar or\n  create your custom style.\n- **Animation Options:** Choose from variety of eye-catching animations for your navigation bar\n  elements, making your app more engaging.\n- **Customization:** Customize colors, icons, and animations to match your app's branding and\n  design.\n\n\n\n## Configuration\n\nAvailable on [Maven Central](https://central.sonatype.com/artifact/com.canopas.compose-animated-navigationbar/bottombar).\n\nAdd the dependency\n```gradle\n    implementation 'com.canopas.compose-animated-navigationbar:bottombar:1.0.1'\n\n```\n\n\n## Sample Usage\n\nIntegrating **AnimatedBottomBarCompose** into your Android app is a breeze! Follow these simple\nsteps to get started:\n\n1. First, set up your navigation controller:\n\n```\nval navController = rememberNavController()\nval navBackStackEntry by navController.currentBackStackEntryAsState()\nval currentRoute = navBackStackEntry?.destination?.route\nval navigationItems = MainNavigation::class.nestedClasses.map {\n    it.objectInstance as MainNavigation\n}\nvar selectedItem by remember { mutableIntStateOf(0) }\n```\n\n2. Next, add **AnimatedBottomBarCompose** to your app's Scaffold as the bottom bar:\n\n```\nScaffold(\n    bottomBar = {\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.take(3).size,\n            containerColor = Color.LightGray,\n            indicatorStyle = IndicatorStyle.LINE\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                BottomBarItem(\n                    selected = currentRoute == navigationItem.route,\n                    onClick = {\n                        if (currentRoute != navigationItem.route) {\n                            selectedItem = index\n                            // ... Navigation Stuff\n                        }\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    containerColor = Color.Transparent\n                )\n            }\n        }\n    }\n) {\n// ... (rest of your app content)\n}\n```\n\n## Demo\n\nTo see **AnimatedBottomBarCompose** in action, check out\nour [Sample](https://github.com/canopas/AnimatedBottomBarCompose/tree/master/app) app where you can\nexplore various styles and animation options.\n\n## Bugs and Feedback\n\nFor bugs, questions and discussions please use\nthe [Github Issues](https://github.com/canopas/AnimatedBottomBarCompose/issues)\n\n## Credits\n\n**AnimatedBottomBarCompose** is owned and maintained by the [Canopas team](https://canopas.com/).\nFor project updates and releases, you can follow them on X\nat [@canopassoftware](https://x.com/canopassoftware).\n\n<a href=\"https://canopas.com/contact\"><img src=\"./cta/cta_btn.png\" width=300></a>\n\n# Licence\n\n```\nCopyright 2023 Canopas Software LLP\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nYou won't be using this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n   http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n```\n"
  },
  {
    "path": "app/.gitignore",
    "content": "/build"
  },
  {
    "path": "app/build.gradle.kts",
    "content": "plugins {\n    id(\"com.android.application\")\n    id(\"org.jetbrains.kotlin.android\")\n}\n\nandroid {\n    namespace = \"com.example.animatedbottombarcompose\"\n    compileSdk = 34\n\n    defaultConfig {\n        applicationId = \"com.example.animatedbottombarcompose\"\n        minSdk = 24\n        versionCode = 1\n        versionName = \"1.0\"\n\n        testInstrumentationRunner = \"androidx.test.runner.AndroidJUnitRunner\"\n        vectorDrawables {\n            useSupportLibrary = true\n        }\n    }\n\n    buildTypes {\n        release {\n            isMinifyEnabled = false\n            proguardFiles(\n                getDefaultProguardFile(\"proguard-android-optimize.txt\"),\n                \"proguard-rules.pro\",\n            )\n        }\n    }\n    compileOptions {\n        sourceCompatibility = JavaVersion.VERSION_11\n        targetCompatibility = JavaVersion.VERSION_11\n    }\n    kotlinOptions {\n        jvmTarget = \"11\"\n    }\n    buildFeatures {\n        compose = true\n    }\n    composeOptions {\n        kotlinCompilerExtensionVersion = \"1.5.3\"\n    }\n    packaging {\n        resources {\n            excludes += \"/META-INF/{AL2.0,LGPL2.1}\"\n        }\n    }\n}\n\ndependencies {\n\n    implementation(\"androidx.lifecycle:lifecycle-runtime-ktx:2.8.1\")\n    implementation(\"androidx.activity:activity-compose:1.9.0\")\n    implementation(platform(\"androidx.compose:compose-bom:2024.05.00\"))\n    implementation(\"androidx.compose.ui:ui\")\n    implementation(\"androidx.compose.ui:ui-graphics\")\n    implementation(\"androidx.navigation:navigation-compose:2.7.7\")\n    implementation(\"androidx.compose.ui:ui-tooling-preview\")\n    implementation(\"androidx.compose.material3:material3\")\n    testImplementation(\"junit:junit:4.13.2\")\n    androidTestImplementation(\"androidx.test.ext:junit:1.1.5\")\n    androidTestImplementation(\"androidx.test.espresso:espresso-core:3.5.1\")\n    androidTestImplementation(platform(\"androidx.compose:compose-bom:2024.05.00\"))\n    androidTestImplementation(\"androidx.compose.ui:ui-test-junit4\")\n    debugImplementation(\"androidx.compose.ui:ui-tooling\")\n    debugImplementation(\"androidx.compose.ui:ui-test-manifest\")\n\n    implementation(project(\":bottombar\"))\n    implementation(kotlin(\"reflect\"))\n}\n"
  },
  {
    "path": "app/proguard-rules.pro",
    "content": "# Add project specific ProGuard rules here.\n# You can control the set of applied configuration files using the\n# proguardFiles setting in build.gradle.\n#\n# For more details, see\n#   http://developer.android.com/guide/developing/tools/proguard.html\n\n# If your project uses WebView with JS, uncomment the following\n# and specify the fully qualified class name to the JavaScript interface\n# class:\n#-keepclassmembers class fqcn.of.javascript.interface.for.webview {\n#   public *;\n#}\n\n# Uncomment this to preserve the line number information for\n# debugging stack traces.\n#-keepattributes SourceFile,LineNumberTable\n\n# If you keep the line number information, uncomment this to\n# hide the original source file name.\n#-renamesourcefileattribute SourceFile"
  },
  {
    "path": "app/src/androidTest/java/com/example/animatedbottombarcompose/ExampleInstrumentedTest.kt",
    "content": "package com.example.animatedbottombarcompose\n\nimport androidx.test.ext.junit.runners.AndroidJUnit4\nimport androidx.test.platform.app.InstrumentationRegistry\nimport org.junit.Assert.*\nimport org.junit.Test\nimport org.junit.runner.RunWith\n\n/**\n * Instrumented test, which will execute on an Android device.\n *\n * See [testing documentation](http://d.android.com/tools/testing).\n */\n@RunWith(AndroidJUnit4::class)\nclass ExampleInstrumentedTest {\n    @Test\n    fun useAppContext() {\n        // Context of the app under test.\n        val appContext = InstrumentationRegistry.getInstrumentation().targetContext\n        assertEquals(\"com.example.animatedbottombarcompose\", appContext.packageName)\n    }\n}\n"
  },
  {
    "path": "app/src/main/AndroidManifest.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<manifest xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    xmlns:tools=\"http://schemas.android.com/tools\">\n\n    <application\n        android:allowBackup=\"true\"\n        android:dataExtractionRules=\"@xml/data_extraction_rules\"\n        android:fullBackupContent=\"@xml/backup_rules\"\n        android:icon=\"@mipmap/ic_launcher\"\n        android:label=\"@string/app_name\"\n        android:roundIcon=\"@mipmap/ic_launcher_round\"\n        android:supportsRtl=\"true\"\n        android:theme=\"@style/Theme.AnimatedBottomBarCompose\"\n        tools:targetApi=\"31\">\n        <activity\n            android:name=\".MainActivity\"\n            android:exported=\"true\"\n            android:label=\"@string/app_name\"\n            android:theme=\"@style/Theme.AnimatedBottomBarCompose\">\n            <intent-filter>\n                <action android:name=\"android.intent.action.MAIN\" />\n\n                <category android:name=\"android.intent.category.LAUNCHER\" />\n            </intent-filter>\n        </activity>\n    </application>\n\n</manifest>"
  },
  {
    "path": "app/src/main/java/com/example/animatedbottombarcompose/MainActivity.kt",
    "content": "package com.example.animatedbottombarcompose\n\nimport android.annotation.SuppressLint\nimport android.os.Bundle\nimport androidx.activity.ComponentActivity\nimport androidx.activity.compose.setContent\nimport androidx.compose.material3.Scaffold\nimport androidx.compose.runtime.getValue\nimport androidx.compose.runtime.mutableIntStateOf\nimport androidx.compose.runtime.remember\nimport androidx.compose.runtime.setValue\nimport androidx.compose.ui.graphics.Color\nimport androidx.navigation.compose.NavHost\nimport androidx.navigation.compose.composable\nimport androidx.navigation.compose.currentBackStackEntryAsState\nimport androidx.navigation.compose.rememberNavController\nimport com.example.animatedbottombarcompose.composables.Screen1\nimport com.example.animatedbottombarcompose.composables.Screen2\nimport com.example.animatedbottombarcompose.composables.Screen3\nimport com.example.animatedbottombarcompose.model.MainNavigation\nimport com.example.animatedbottombarcompose.ui.theme.AnimatedBottomBarComposeTheme\nimport com.example.bottombar.AnimatedBottomBar\nimport com.example.bottombar.components.BottomBarItem\nimport com.example.bottombar.model.IndicatorStyle\n\nclass MainActivity : ComponentActivity() {\n    @SuppressLint(\"UnusedMaterial3ScaffoldPaddingParameter\")\n    override fun onCreate(savedInstanceState: Bundle?) {\n        super.onCreate(savedInstanceState)\n        setContent {\n            AnimatedBottomBarComposeTheme {\n                val navController = rememberNavController()\n                val navBackStackEntry by navController.currentBackStackEntryAsState()\n                val currentRoute = navBackStackEntry?.destination?.route\n                val navigationItems =\n                    MainNavigation::class.nestedClasses.map {\n                        it.objectInstance as MainNavigation\n                    }\n                var selectedItem by remember { mutableIntStateOf(0) }\n\n                Scaffold(\n                    bottomBar = {\n                        AnimatedBottomBar(\n                            selectedItem = selectedItem,\n                            itemSize = navigationItems.take(3).size,\n                            containerColor = Color.LightGray,\n                            indicatorStyle = IndicatorStyle.DOT,\n                        ) {\n                            navigationItems.take(3).forEachIndexed { index, navigationItem ->\n                                BottomBarItem(\n                                    selected = currentRoute == navigationItem.route,\n                                    onClick = {\n                                        if (currentRoute != navigationItem.route) {\n                                            selectedItem = index\n                                            navController.popBackStack()\n                                            navController.navigate(navigationItem.route) {\n                                                navController.graph.startDestinationRoute?.let { route ->\n                                                    popUpTo(route) {\n                                                        saveState = true\n                                                    }\n                                                }\n                                                launchSingleTop = true\n                                                restoreState = true\n                                            }\n                                        }\n                                    },\n                                    imageVector = navigationItem.icon,\n                                    label = navigationItem.title,\n                                    containerColor = Color.Transparent,\n                                )\n                            }\n                        }\n                    },\n                ) {\n                    NavHost(\n                        navController = navController,\n                        startDestination = MainNavigation.ScreenA.route,\n                    ) {\n                        composable(MainNavigation.ScreenA.route) {\n                            Screen1(navigationItems)\n                        }\n                        composable(MainNavigation.ScreenB.route) {\n                            Screen2(navigationItems)\n                        }\n                        composable(MainNavigation.ScreenC.route) {\n                            Screen3(navigationItems)\n                        }\n                    }\n                }\n            }\n        }\n    }\n}\n"
  },
  {
    "path": "app/src/main/java/com/example/animatedbottombarcompose/composables/Screen1.kt",
    "content": "package com.example.animatedbottombarcompose.composables\n\nimport androidx.compose.foundation.layout.Arrangement\nimport androidx.compose.foundation.layout.Column\nimport androidx.compose.foundation.layout.Spacer\nimport androidx.compose.foundation.layout.fillMaxSize\nimport androidx.compose.foundation.layout.fillMaxWidth\nimport androidx.compose.foundation.layout.height\nimport androidx.compose.foundation.layout.padding\nimport androidx.compose.foundation.rememberScrollState\nimport androidx.compose.foundation.shape.RoundedCornerShape\nimport androidx.compose.foundation.verticalScroll\nimport androidx.compose.material3.MaterialTheme\nimport androidx.compose.material3.Text\nimport androidx.compose.runtime.Composable\nimport androidx.compose.runtime.getValue\nimport androidx.compose.runtime.mutableIntStateOf\nimport androidx.compose.runtime.remember\nimport androidx.compose.runtime.setValue\nimport androidx.compose.ui.Modifier\nimport androidx.compose.ui.graphics.Brush\nimport androidx.compose.ui.graphics.Color\nimport androidx.compose.ui.text.style.TextAlign\nimport androidx.compose.ui.unit.dp\nimport com.example.animatedbottombarcompose.model.MainNavigation\nimport com.example.bottombar.AnimatedBottomBar\nimport com.example.bottombar.components.BottomBarItem\nimport com.example.bottombar.model.IndicatorDirection\nimport com.example.bottombar.model.IndicatorStyle\nimport com.example.bottombar.model.ItemStyle\nimport com.example.bottombar.model.VisibleItem\n\n@Composable\nfun Screen1(navigationItems: List<MainNavigation>) {\n    var selectedItem by remember { mutableIntStateOf(0) }\n\n    Column(\n        modifier =\n            Modifier\n                .fillMaxSize()\n                .verticalScroll(rememberScrollState()),\n        verticalArrangement = Arrangement.Top,\n    ) {\n        Text(\n            text = \"**Checkout INDICATORS with different STYLES(animations)**\",\n            style = MaterialTheme.typography.titleMedium,\n            modifier =\n                Modifier\n                    .fillMaxWidth()\n                    .padding(top = 20.dp),\n            textAlign = TextAlign.Center,\n        )\n        Spacer(modifier = Modifier.height(50.dp))\n\n        Text(\n            text = \"LINE INDICATOR\",\n            style = MaterialTheme.typography.headlineSmall,\n            modifier = Modifier.fillMaxWidth(),\n            textAlign = TextAlign.Center,\n        )\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = IndicatorStyle.LINE,\n            containerShape = RoundedCornerShape(topStart = 10.dp, topEnd = 10.dp),\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    visibleItem = VisibleItem.ICON,\n                    itemStyle = ItemStyle.STYLE1,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = IndicatorStyle.LINE,\n            containerShape = RoundedCornerShape(topStart = 10.dp, topEnd = 10.dp),\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    visibleItem = VisibleItem.LABEL,\n                    itemStyle = ItemStyle.STYLE1,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = IndicatorStyle.LINE,\n            containerShape = RoundedCornerShape(topStart = 10.dp, topEnd = 10.dp),\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    visibleItem = VisibleItem.BOTH,\n                    itemStyle = ItemStyle.STYLE1,\n                )\n            }\n        }\n        Spacer(modifier = Modifier.height(25.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = IndicatorStyle.LINE,\n            containerShape = RoundedCornerShape(topStart = 10.dp, topEnd = 10.dp),\n            indicatorDirection = IndicatorDirection.BOTTOM,\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    visibleItem = VisibleItem.ICON,\n                    itemStyle = ItemStyle.STYLE3,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = IndicatorStyle.LINE,\n            containerShape = RoundedCornerShape(topStart = 10.dp, topEnd = 10.dp),\n            indicatorDirection = IndicatorDirection.BOTTOM,\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    visibleItem = VisibleItem.LABEL,\n                    itemStyle = ItemStyle.STYLE4,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = IndicatorStyle.LINE,\n            containerShape = RoundedCornerShape(topStart = 10.dp, topEnd = 10.dp),\n            indicatorDirection = IndicatorDirection.BOTTOM,\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    visibleItem = VisibleItem.BOTH,\n                    itemStyle = ItemStyle.STYLE5,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(50.dp))\n\n        Text(\n            text = \"DOT INDICATOR\",\n            style = MaterialTheme.typography.headlineSmall,\n            modifier = Modifier.fillMaxWidth(),\n            textAlign = TextAlign.Center,\n        )\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.errorContainer,\n            indicatorStyle = IndicatorStyle.DOT,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    itemStyle = ItemStyle.STYLE1,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.errorContainer,\n            indicatorStyle = IndicatorStyle.DOT,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    textColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    itemStyle = ItemStyle.STYLE3,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.errorContainer,\n            indicatorStyle = IndicatorStyle.DOT,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    textColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    itemStyle = ItemStyle.STYLE4,\n                    activeIndicatorColor = Color.White,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.errorContainer,\n            indicatorStyle = IndicatorStyle.DOT,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    textColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    itemStyle = ItemStyle.STYLE5,\n                    activeIndicatorColor = Color.White,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(50.dp))\n\n        Text(\n            text = \"WORM INDICATOR\",\n            style = MaterialTheme.typography.headlineSmall,\n            modifier = Modifier.fillMaxWidth(),\n            textAlign = TextAlign.Center,\n        )\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.tertiaryContainer,\n            indicatorStyle = IndicatorStyle.WORM,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    textColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    itemStyle = ItemStyle.STYLE1,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.tertiaryContainer,\n            indicatorStyle = IndicatorStyle.WORM,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    textColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    itemStyle = ItemStyle.STYLE3,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.tertiaryContainer,\n            indicatorStyle = IndicatorStyle.WORM,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    textColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    itemStyle = ItemStyle.STYLE4,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.tertiaryContainer,\n            indicatorStyle = IndicatorStyle.WORM,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    textColor = if (selected) Color.Black else Color.Black.copy(0.8f),\n                    itemStyle = ItemStyle.STYLE5,\n                    activeIndicatorColor = Color.White,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(50.dp))\n\n        Text(\n            text = \"FILLED INDICATOR\",\n            style = MaterialTheme.typography.headlineSmall,\n            modifier = Modifier.fillMaxWidth(),\n            textAlign = TextAlign.Center,\n        )\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n            indicatorStyle = IndicatorStyle.FILLED,\n            indicatorColor = MaterialTheme.colorScheme.background,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    itemStyle = ItemStyle.STYLE1,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n            indicatorStyle = IndicatorStyle.FILLED,\n            indicatorColor = MaterialTheme.colorScheme.background,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    itemStyle = ItemStyle.STYLE3,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n            indicatorStyle = IndicatorStyle.FILLED,\n            indicatorColor = MaterialTheme.colorScheme.background,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    itemStyle = ItemStyle.STYLE4,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n            indicatorStyle = IndicatorStyle.FILLED,\n            indicatorColor = MaterialTheme.colorScheme.background,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    itemStyle = ItemStyle.STYLE5,\n                    iconColor = if (selected) Color.White else Color.Black,\n                    glowingBackground =\n                        Brush.radialGradient(\n                            listOf(\n                                Color.Black,\n                                Color.Transparent,\n                                Color.Transparent,\n                            ),\n                        ),\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(25.dp))\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            containerColor = MaterialTheme.colorScheme.secondaryContainer,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    itemStyle = ItemStyle.STYLE2,\n                    iconColor = if (selected) Color.Black else Color.White,\n                    textColor = if (selected) Color.Black else Color.White,\n                    activeIndicatorColor = Color.White,\n                )\n            }\n        }\n        Spacer(modifier = Modifier.height(150.dp))\n    }\n}\n"
  },
  {
    "path": "app/src/main/java/com/example/animatedbottombarcompose/composables/Screen2.kt",
    "content": "package com.example.animatedbottombarcompose.composables\n\nimport androidx.compose.foundation.layout.Column\nimport androidx.compose.foundation.layout.Row\nimport androidx.compose.foundation.layout.Spacer\nimport androidx.compose.foundation.layout.fillMaxSize\nimport androidx.compose.foundation.layout.fillMaxWidth\nimport androidx.compose.foundation.layout.height\nimport androidx.compose.foundation.layout.padding\nimport androidx.compose.foundation.rememberScrollState\nimport androidx.compose.foundation.verticalScroll\nimport androidx.compose.material3.MaterialTheme\nimport androidx.compose.material3.RadioButton\nimport androidx.compose.material3.Text\nimport androidx.compose.runtime.Composable\nimport androidx.compose.runtime.getValue\nimport androidx.compose.runtime.mutableIntStateOf\nimport androidx.compose.runtime.mutableStateOf\nimport androidx.compose.runtime.remember\nimport androidx.compose.runtime.setValue\nimport androidx.compose.ui.Alignment\nimport androidx.compose.ui.Modifier\nimport androidx.compose.ui.graphics.Brush\nimport androidx.compose.ui.graphics.Color\nimport androidx.compose.ui.unit.dp\nimport com.example.animatedbottombarcompose.model.MainNavigation\nimport com.example.bottombar.AnimatedBottomBar\nimport com.example.bottombar.components.BottomBarItem\nimport com.example.bottombar.model.IndicatorStyle\nimport com.example.bottombar.model.ItemStyle\n\n@Composable\nfun Screen2(navigationItems: List<MainNavigation>) {\n    var selectedItem by remember { mutableIntStateOf(0) }\n    var itemStyle: ItemStyle by remember {\n        mutableStateOf(ItemStyle.STYLE3)\n    }\n    var indicatorStyle: IndicatorStyle by remember {\n        mutableStateOf(IndicatorStyle.WORM)\n    }\n    val itemStyles =\n        listOf(\n            ItemStyle.STYLE1,\n            ItemStyle.STYLE2,\n            ItemStyle.STYLE3,\n            ItemStyle.STYLE4,\n            ItemStyle.STYLE5,\n        )\n    val indicatorStyles =\n        listOf(\n            IndicatorStyle.NONE,\n            IndicatorStyle.LINE,\n            IndicatorStyle.DOT,\n            IndicatorStyle.WORM,\n        )\n    Column(\n        modifier =\n            Modifier\n                .fillMaxSize()\n                .verticalScroll(rememberScrollState()),\n    ) {\n        Spacer(modifier = Modifier.height(50.dp))\n\n        Text(\n            text = \"Item Style:\",\n            style = MaterialTheme.typography.titleMedium,\n            modifier = Modifier.padding(horizontal = 8.dp),\n        )\n        Column(\n            modifier =\n                Modifier\n                    .fillMaxWidth()\n                    .padding(horizontal = 8.dp),\n        ) {\n            Row(verticalAlignment = Alignment.CenterVertically) {\n                itemStyles.take(3).forEach {\n                    RadioButton(selected = it == itemStyle, onClick = {\n                        itemStyle = it\n                    })\n                    Text(text = it.name)\n                }\n            }\n            Row(verticalAlignment = Alignment.CenterVertically) {\n                itemStyles.takeLast(2).forEach {\n                    RadioButton(selected = it == itemStyle, onClick = {\n                        itemStyle = it\n                    })\n                    Text(text = it.name)\n                }\n            }\n        }\n\n        Text(\n            text = \"Indicator Style:\",\n            style = MaterialTheme.typography.titleMedium,\n            modifier = Modifier.padding(horizontal = 8.dp),\n        )\n        Column(\n            modifier =\n                Modifier\n                    .fillMaxWidth()\n                    .padding(horizontal = 8.dp),\n        ) {\n            Row(verticalAlignment = Alignment.CenterVertically) {\n                indicatorStyles.take(2).forEach {\n                    RadioButton(selected = it == indicatorStyle, onClick = {\n                        indicatorStyle = it\n                    })\n                    Text(text = it.name)\n                }\n            }\n            Row(verticalAlignment = Alignment.CenterVertically) {\n                indicatorStyles.takeLast(2).forEach {\n                    RadioButton(selected = it == indicatorStyle, onClick = {\n                        indicatorStyle = it\n                    })\n                    Text(text = it.name)\n                }\n            }\n        }\n\n        Spacer(modifier = Modifier.height(100.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = if (itemStyle != ItemStyle.STYLE2) indicatorStyle else IndicatorStyle.NONE,\n            containerColor = Color.Transparent,\n            indicatorColor = Color.Red,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Red else Color.Black,\n                    textColor = if (selected) Color.Red else Color.Black,\n                    itemStyle = itemStyle,\n                    glowingBackground =\n                        Brush.radialGradient(\n                            listOf(\n                                Color.Red.copy(0.5f),\n                                Color.Transparent,\n                                Color.Transparent,\n                            ),\n                        ),\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(50.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = if (itemStyle != ItemStyle.STYLE2) indicatorStyle else IndicatorStyle.NONE,\n            indicatorColor = Color.White,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.White else Color.Black,\n                    textColor = if (selected) Color.White else Color.Black,\n                    itemStyle = itemStyle,\n                    glowingBackground =\n                        Brush.radialGradient(\n                            listOf(\n                                Color.Black,\n                                Color.Transparent,\n                                Color.Transparent,\n                            ),\n                        ),\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(150.dp))\n    }\n}\n"
  },
  {
    "path": "app/src/main/java/com/example/animatedbottombarcompose/composables/Screen3.kt",
    "content": "package com.example.animatedbottombarcompose.composables\n\nimport androidx.compose.foundation.layout.Column\nimport androidx.compose.foundation.layout.Row\nimport androidx.compose.foundation.layout.Spacer\nimport androidx.compose.foundation.layout.fillMaxSize\nimport androidx.compose.foundation.layout.fillMaxWidth\nimport androidx.compose.foundation.layout.height\nimport androidx.compose.foundation.layout.padding\nimport androidx.compose.foundation.rememberScrollState\nimport androidx.compose.foundation.verticalScroll\nimport androidx.compose.material3.MaterialTheme\nimport androidx.compose.material3.RadioButton\nimport androidx.compose.material3.Text\nimport androidx.compose.runtime.Composable\nimport androidx.compose.runtime.getValue\nimport androidx.compose.runtime.mutableIntStateOf\nimport androidx.compose.runtime.mutableStateOf\nimport androidx.compose.runtime.remember\nimport androidx.compose.runtime.setValue\nimport androidx.compose.ui.Alignment\nimport androidx.compose.ui.Modifier\nimport androidx.compose.ui.graphics.Color\nimport androidx.compose.ui.unit.dp\nimport com.example.animatedbottombarcompose.model.MainNavigation\nimport com.example.bottombar.AnimatedBottomBar\nimport com.example.bottombar.components.BottomBarItem\nimport com.example.bottombar.model.IndicatorStyle\nimport com.example.bottombar.model.ItemStyle\n\n@Composable\nfun Screen3(navigationItems: List<MainNavigation>) {\n    var selectedItem by remember { mutableIntStateOf(0) }\n    var itemStyle: ItemStyle by remember {\n        mutableStateOf(ItemStyle.STYLE3)\n    }\n    val itemStyles =\n        listOf(\n            ItemStyle.STYLE1,\n            ItemStyle.STYLE2,\n            ItemStyle.STYLE3,\n            ItemStyle.STYLE4,\n            ItemStyle.STYLE5,\n        )\n    Column(\n        modifier =\n            Modifier\n                .fillMaxSize()\n                .verticalScroll(rememberScrollState()),\n    ) {\n        Spacer(modifier = Modifier.height(50.dp))\n\n        Text(\n            text = \"Item Style:\",\n            style = MaterialTheme.typography.titleMedium,\n            modifier = Modifier.padding(horizontal = 8.dp),\n        )\n        Column(\n            modifier =\n                Modifier\n                    .fillMaxWidth()\n                    .padding(horizontal = 8.dp),\n        ) {\n            Row(verticalAlignment = Alignment.CenterVertically) {\n                itemStyles.take(3).forEach {\n                    RadioButton(selected = it == itemStyle, onClick = {\n                        itemStyle = it\n                    })\n                    Text(text = it.name)\n                }\n            }\n            Row(verticalAlignment = Alignment.CenterVertically) {\n                itemStyles.takeLast(2).forEach {\n                    RadioButton(selected = it == itemStyle, onClick = {\n                        itemStyle = it\n                    })\n                    Text(text = it.name)\n                }\n            }\n        }\n\n        Spacer(modifier = Modifier.height(100.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = if (itemStyle != ItemStyle.STYLE2) IndicatorStyle.FILLED else IndicatorStyle.NONE,\n            containerColor = Color.Transparent,\n            indicatorColor = Color.Red.copy(0.5f),\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.White else Color.Black,\n                    textColor = if (selected) Color.White else Color.Black,\n                    itemStyle = itemStyle,\n                    activeIndicatorColor = Color.Red.copy(0.5f),\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(50.dp))\n\n        AnimatedBottomBar(\n            selectedItem = selectedItem,\n            itemSize = navigationItems.size,\n            indicatorStyle = if (itemStyle != ItemStyle.STYLE2) IndicatorStyle.FILLED else IndicatorStyle.NONE,\n            indicatorColor = Color.White,\n        ) {\n            navigationItems.forEachIndexed { index, navigationItem ->\n                val selected = index == selectedItem\n                BottomBarItem(\n                    selected = selected,\n                    onClick = {\n                        selectedItem = index\n                    },\n                    imageVector = navigationItem.icon,\n                    label = navigationItem.title,\n                    iconColor = if (selected) Color.Black else Color.White,\n                    textColor = if (selected) Color.Black else Color.White,\n                    itemStyle = itemStyle,\n                    activeIndicatorColor = Color.White,\n                )\n            }\n        }\n\n        Spacer(modifier = Modifier.height(150.dp))\n    }\n}\n"
  },
  {
    "path": "app/src/main/java/com/example/animatedbottombarcompose/model/MainNavigation.kt",
    "content": "package com.example.animatedbottombarcompose.model\n\nimport androidx.compose.material.icons.Icons\nimport androidx.compose.material.icons.outlined.Email\nimport androidx.compose.material.icons.outlined.FavoriteBorder\nimport androidx.compose.material.icons.outlined.Home\nimport androidx.compose.material.icons.outlined.Notifications\nimport androidx.compose.ui.graphics.vector.ImageVector\n\nsealed class MainNavigation(\n    val title: String,\n    val route: String,\n    val icon: ImageVector,\n) {\n    data object ScreenA : MainNavigation(\n        title = \"Screen1\",\n        route = \"Screen1\",\n        icon = Icons.Outlined.Home,\n    )\n\n    data object ScreenB : MainNavigation(\n        title = \"Screen2\",\n        route = \"Screen2\",\n        icon = Icons.Outlined.Notifications,\n    )\n\n    data object ScreenC : MainNavigation(\n        title = \"Screen3\",\n        route = \"Screen3\",\n        icon = Icons.Outlined.FavoriteBorder,\n    )\n\n    data object ScreenD : MainNavigation(\n        title = \"Screen4\",\n        route = \"Screen4\",\n        icon = Icons.Outlined.Email,\n    )\n}\n"
  },
  {
    "path": "app/src/main/java/com/example/animatedbottombarcompose/ui/theme/Color.kt",
    "content": "package com.example.animatedbottombarcompose.ui.theme\n\nimport androidx.compose.ui.graphics.Color\n\nval Purple80 = Color(0xFFD0BCFF)\nval PurpleGrey80 = Color(0xFFCCC2DC)\nval Pink80 = Color(0xFFEFB8C8)\n\nval Purple40 = Color(0xFF6650a4)\nval PurpleGrey40 = Color(0xFF625b71)\nval Pink40 = Color(0xFF7D5260)\n"
  },
  {
    "path": "app/src/main/java/com/example/animatedbottombarcompose/ui/theme/Theme.kt",
    "content": "package com.example.animatedbottombarcompose.ui.theme\n\nimport android.app.Activity\nimport android.os.Build\nimport androidx.compose.foundation.isSystemInDarkTheme\nimport androidx.compose.material3.MaterialTheme\nimport androidx.compose.material3.darkColorScheme\nimport androidx.compose.material3.dynamicDarkColorScheme\nimport androidx.compose.material3.dynamicLightColorScheme\nimport androidx.compose.material3.lightColorScheme\nimport androidx.compose.runtime.Composable\nimport androidx.compose.runtime.SideEffect\nimport androidx.compose.ui.graphics.toArgb\nimport androidx.compose.ui.platform.LocalContext\nimport androidx.compose.ui.platform.LocalView\nimport androidx.core.view.WindowCompat\n\nprivate val DarkColorScheme =\n    darkColorScheme(\n        primary = Purple80,\n        secondary = PurpleGrey80,\n        tertiary = Pink80,\n    )\n\nprivate val LightColorScheme =\n    lightColorScheme(\n        primary = Purple40,\n        secondary = PurpleGrey40,\n        tertiary = Pink40,\n    /* Other default colors to override\n    background = Color(0xFFFFFBFE),\n    surface = Color(0xFFFFFBFE),\n    onPrimary = Color.White,\n    onSecondary = Color.White,\n    onTertiary = Color.White,\n    onBackground = Color(0xFF1C1B1F),\n    onSurface = Color(0xFF1C1B1F),\n     */\n    )\n\n@Composable\nfun AnimatedBottomBarComposeTheme(\n    darkTheme: Boolean = isSystemInDarkTheme(),\n    // Dynamic color is available on Android 12+\n    dynamicColor: Boolean = true,\n    content: @Composable () -> Unit,\n) {\n    val colorScheme =\n        when {\n            dynamicColor && Build.VERSION.SDK_INT >= Build.VERSION_CODES.S -> {\n                val context = LocalContext.current\n                if (darkTheme) dynamicDarkColorScheme(context) else dynamicLightColorScheme(context)\n            }\n\n            darkTheme -> DarkColorScheme\n            else -> LightColorScheme\n        }\n    val view = LocalView.current\n    if (!view.isInEditMode) {\n        SideEffect {\n            val window = (view.context as Activity).window\n            window.statusBarColor = colorScheme.primary.toArgb()\n            WindowCompat.getInsetsController(window, view).isAppearanceLightStatusBars = darkTheme\n        }\n    }\n\n    MaterialTheme(\n        colorScheme = colorScheme,\n        typography = Typography,\n        content = content,\n    )\n}\n"
  },
  {
    "path": "app/src/main/java/com/example/animatedbottombarcompose/ui/theme/Type.kt",
    "content": "package com.example.animatedbottombarcompose.ui.theme\n\nimport androidx.compose.material3.Typography\nimport androidx.compose.ui.text.TextStyle\nimport androidx.compose.ui.text.font.FontFamily\nimport androidx.compose.ui.text.font.FontWeight\nimport androidx.compose.ui.unit.sp\n\n// Set of Material typography styles to start with\nval Typography =\n    Typography(\n        bodyLarge =\n            TextStyle(\n                fontFamily = FontFamily.Default,\n                fontWeight = FontWeight.Normal,\n                fontSize = 16.sp,\n                lineHeight = 24.sp,\n                letterSpacing = 0.5.sp,\n            ),\n    /* Other default text styles to override\n    titleLarge = TextStyle(\n        fontFamily = FontFamily.Default,\n        fontWeight = FontWeight.Normal,\n        fontSize = 22.sp,\n        lineHeight = 28.sp,\n        letterSpacing = 0.sp\n    ),\n    labelSmall = TextStyle(\n        fontFamily = FontFamily.Default,\n        fontWeight = FontWeight.Medium,\n        fontSize = 11.sp,\n        lineHeight = 16.sp,\n        letterSpacing = 0.5.sp\n    )\n     */\n    )\n"
  },
  {
    "path": "app/src/main/res/drawable/ic_launcher_background.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<vector xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    android:width=\"108dp\"\n    android:height=\"108dp\"\n    android:viewportWidth=\"108\"\n    android:viewportHeight=\"108\">\n    <path\n        android:fillColor=\"#3DDC84\"\n        android:pathData=\"M0,0h108v108h-108z\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M9,0L9,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M19,0L19,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M29,0L29,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M39,0L39,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M49,0L49,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M59,0L59,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M69,0L69,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M79,0L79,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M89,0L89,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M99,0L99,108\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,9L108,9\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,19L108,19\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,29L108,29\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,39L108,39\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,49L108,49\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,59L108,59\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,69L108,69\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,79L108,79\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,89L108,89\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M0,99L108,99\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M19,29L89,29\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M19,39L89,39\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M19,49L89,49\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M19,59L89,59\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M19,69L89,69\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M19,79L89,79\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M29,19L29,89\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M39,19L39,89\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M49,19L49,89\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M59,19L59,89\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M69,19L69,89\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n    <path\n        android:fillColor=\"#00000000\"\n        android:pathData=\"M79,19L79,89\"\n        android:strokeWidth=\"0.8\"\n        android:strokeColor=\"#33FFFFFF\" />\n</vector>\n"
  },
  {
    "path": "app/src/main/res/drawable/ic_launcher_foreground.xml",
    "content": "<vector xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    xmlns:aapt=\"http://schemas.android.com/aapt\"\n    android:width=\"108dp\"\n    android:height=\"108dp\"\n    android:viewportWidth=\"108\"\n    android:viewportHeight=\"108\">\n    <path android:pathData=\"M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z\">\n        <aapt:attr name=\"android:fillColor\">\n            <gradient\n                android:endX=\"85.84757\"\n                android:endY=\"92.4963\"\n                android:startX=\"42.9492\"\n                android:startY=\"49.59793\"\n                android:type=\"linear\">\n                <item\n                    android:color=\"#44000000\"\n                    android:offset=\"0.0\" />\n                <item\n                    android:color=\"#00000000\"\n                    android:offset=\"1.0\" />\n            </gradient>\n        </aapt:attr>\n    </path>\n    <path\n        android:fillColor=\"#FFFFFF\"\n        android:fillType=\"nonZero\"\n        android:pathData=\"M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z\"\n        android:strokeWidth=\"1\"\n        android:strokeColor=\"#00000000\" />\n</vector>"
  },
  {
    "path": "app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<adaptive-icon xmlns:android=\"http://schemas.android.com/apk/res/android\">\n    <background android:drawable=\"@drawable/ic_launcher_background\" />\n    <foreground android:drawable=\"@drawable/ic_launcher_foreground\" />\n    <monochrome android:drawable=\"@drawable/ic_launcher_foreground\" />\n</adaptive-icon>"
  },
  {
    "path": "app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<adaptive-icon xmlns:android=\"http://schemas.android.com/apk/res/android\">\n    <background android:drawable=\"@drawable/ic_launcher_background\" />\n    <foreground android:drawable=\"@drawable/ic_launcher_foreground\" />\n    <monochrome android:drawable=\"@drawable/ic_launcher_foreground\" />\n</adaptive-icon>"
  },
  {
    "path": "app/src/main/res/values/colors.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<resources>\n    <color name=\"purple_200\">#FFBB86FC</color>\n    <color name=\"purple_500\">#FF6200EE</color>\n    <color name=\"purple_700\">#FF3700B3</color>\n    <color name=\"teal_200\">#FF03DAC5</color>\n    <color name=\"teal_700\">#FF018786</color>\n    <color name=\"black\">#FF000000</color>\n    <color name=\"white\">#FFFFFFFF</color>\n</resources>"
  },
  {
    "path": "app/src/main/res/values/strings.xml",
    "content": "<resources>\n    <string name=\"app_name\">AnimatedBottomBarCompose</string>\n</resources>"
  },
  {
    "path": "app/src/main/res/values/themes.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<resources>\n\n    <style name=\"Theme.AnimatedBottomBarCompose\" parent=\"android:Theme.Material.Light.NoActionBar\" />\n</resources>"
  },
  {
    "path": "app/src/main/res/xml/backup_rules.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?><!--\n   Sample backup rules file; uncomment and customize as necessary.\n   See https://developer.android.com/guide/topics/data/autobackup\n   for details.\n   Note: This file is ignored for devices older that API 31\n   See https://developer.android.com/about/versions/12/backup-restore\n-->\n<full-backup-content>\n    <!--\n   <include domain=\"sharedpref\" path=\".\"/>\n   <exclude domain=\"sharedpref\" path=\"device.xml\"/>\n-->\n</full-backup-content>"
  },
  {
    "path": "app/src/main/res/xml/data_extraction_rules.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?><!--\n   Sample data extraction rules file; uncomment and customize as necessary.\n   See https://developer.android.com/about/versions/12/backup-restore#xml-changes\n   for details.\n-->\n<data-extraction-rules>\n    <cloud-backup>\n        <!-- TODO: Use <include> and <exclude> to control what is backed up.\n        <include .../>\n        <exclude .../>\n        -->\n    </cloud-backup>\n    <!--\n    <device-transfer>\n        <include .../>\n        <exclude .../>\n    </device-transfer>\n    -->\n</data-extraction-rules>"
  },
  {
    "path": "app/src/test/java/com/example/animatedbottombarcompose/ExampleUnitTest.kt",
    "content": "package com.example.animatedbottombarcompose\n\nimport org.junit.Assert.assertEquals\nimport org.junit.Test\n\n/**\n * Example local unit test, which will execute on the development machine (host).\n *\n * See [testing documentation](http://d.android.com/tools/testing).\n */\nclass ExampleUnitTest {\n    @Test\n    fun addition_isCorrect() {\n        assertEquals(4, 2 + 2)\n    }\n}\n"
  },
  {
    "path": "bottombar/.gitignore",
    "content": "/build"
  },
  {
    "path": "bottombar/build.gradle.kts",
    "content": "plugins {\n    id(\"com.android.library\")\n    id(\"org.jetbrains.kotlin.android\")\n}\n\next {\n    set(\"PUBLISH_GROUP_ID\", \"com.canopas.compose-animated-navigationbar\")\n    set(\"PUBLISH_ARTIFACT_ID\", \"bottombar\")\n}\n\napply {\n    from(\"$rootDir/scripts/publish-module.gradle\")\n}\n\nandroid {\n    namespace = \"com.example.bottombar\"\n    compileSdk = 34\n\n    defaultConfig {\n        minSdk = 24\n        targetSdk = 34\n\n        testInstrumentationRunner = \"androidx.test.runner.AndroidJUnitRunner\"\n        consumerProguardFiles(\"consumer-rules.pro\")\n        vectorDrawables {\n            useSupportLibrary = true\n        }\n    }\n\n    buildTypes {\n        release {\n            isMinifyEnabled = false\n            proguardFiles(\n                getDefaultProguardFile(\"proguard-android-optimize.txt\"),\n                \"proguard-rules.pro\",\n            )\n        }\n    }\n    compileOptions {\n        sourceCompatibility = JavaVersion.VERSION_17\n        targetCompatibility = JavaVersion.VERSION_17\n    }\n    kotlinOptions {\n        jvmTarget = \"17\"\n    }\n    buildFeatures {\n        compose = true\n    }\n    composeOptions {\n        kotlinCompilerExtensionVersion = \"1.5.3\"\n    }\n    packaging {\n        resources {\n            excludes += \"/META-INF/{AL2.0,LGPL2.1}\"\n        }\n    }\n\n    publishing {\n        singleVariant(\"release\") {\n            withSourcesJar()\n        }\n    }\n}\n\ndependencies {\n\n    implementation(\"androidx.lifecycle:lifecycle-runtime-ktx:2.8.1\")\n    implementation(\"androidx.activity:activity-compose:1.9.0\")\n    implementation(platform(\"androidx.compose:compose-bom:2024.05.00\"))\n    implementation(\"androidx.compose.ui:ui\")\n    implementation(\"androidx.compose.ui:ui-graphics\")\n    implementation(\"androidx.compose.ui:ui-tooling-preview\")\n    implementation(\"androidx.compose.material3:material3\")\n    testImplementation(\"junit:junit:4.13.2\")\n    androidTestImplementation(\"androidx.test.ext:junit:1.1.5\")\n    androidTestImplementation(\"androidx.test.espresso:espresso-core:3.5.1\")\n}\n"
  },
  {
    "path": "bottombar/consumer-rules.pro",
    "content": ""
  },
  {
    "path": "bottombar/proguard-rules.pro",
    "content": "# Add project specific ProGuard rules here.\n# You can control the set of applied configuration files using the\n# proguardFiles setting in build.gradle.\n#\n# For more details, see\n#   http://developer.android.com/guide/developing/tools/proguard.html\n\n# If your project uses WebView with JS, uncomment the following\n# and specify the fully qualified class name to the JavaScript interface\n# class:\n#-keepclassmembers class fqcn.of.javascript.interface.for.webview {\n#   public *;\n#}\n\n# Uncomment this to preserve the line number information for\n# debugging stack traces.\n#-keepattributes SourceFile,LineNumberTable\n\n# If you keep the line number information, uncomment this to\n# hide the original source file name.\n#-renamesourcefileattribute SourceFile"
  },
  {
    "path": "bottombar/src/androidTest/java/com/example/bottombar/ExampleInstrumentedTest.kt",
    "content": "package com.example.bottombar\n\nimport androidx.test.ext.junit.runners.AndroidJUnit4\nimport androidx.test.platform.app.InstrumentationRegistry\nimport org.junit.Assert.*\nimport org.junit.Test\nimport org.junit.runner.RunWith\n\n/**\n * Instrumented test, which will execute on an Android device.\n *\n * See [testing documentation](http://d.android.com/tools/testing).\n */\n@RunWith(AndroidJUnit4::class)\nclass ExampleInstrumentedTest {\n    @Test\n    fun useAppContext() {\n        // Context of the app under test.\n        val appContext = InstrumentationRegistry.getInstrumentation().targetContext\n        assertEquals(\"com.example.bottombar.test\", appContext.packageName)\n    }\n}\n"
  },
  {
    "path": "bottombar/src/main/AndroidManifest.xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<manifest>\n\n</manifest>"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/AnimatedBottomBar.kt",
    "content": "package com.example.bottombar\n\nimport androidx.compose.animation.core.AnimationSpec\nimport androidx.compose.animation.core.Spring\nimport androidx.compose.animation.core.animateDpAsState\nimport androidx.compose.animation.core.spring\nimport androidx.compose.foundation.layout.Arrangement\nimport androidx.compose.foundation.layout.BoxWithConstraints\nimport androidx.compose.foundation.layout.Row\nimport androidx.compose.foundation.layout.RowScope\nimport androidx.compose.foundation.layout.fillMaxWidth\nimport androidx.compose.foundation.layout.height\nimport androidx.compose.foundation.layout.padding\nimport androidx.compose.foundation.selection.selectableGroup\nimport androidx.compose.foundation.shape.RoundedCornerShape\nimport androidx.compose.material3.MaterialTheme\nimport androidx.compose.material3.Surface\nimport androidx.compose.runtime.Composable\nimport androidx.compose.runtime.getValue\nimport androidx.compose.ui.Alignment\nimport androidx.compose.ui.Modifier\nimport androidx.compose.ui.graphics.Color\nimport androidx.compose.ui.graphics.RectangleShape\nimport androidx.compose.ui.graphics.Shape\nimport androidx.compose.ui.unit.Dp\nimport androidx.compose.ui.unit.dp\nimport com.example.bottombar.components.DotIndicator\nimport com.example.bottombar.components.FilledIndicator\nimport com.example.bottombar.components.LineIndicator\nimport com.example.bottombar.components.WormIndicator\nimport com.example.bottombar.model.IndicatorDirection\nimport com.example.bottombar.model.IndicatorStyle\nimport com.example.bottombar.utils.conditional\n\nval DEFAULT_INDICATOR_HEIGHT = 4.dp\n\n/**\n * A composable function that creates layout for bottom navigation & indicator over it.\n *\n *@param [modifier] Modifier to be applied to the navigation bar.\n *@param [bottomBarHeight] The default height of the bottom bar.\n *@param [containerColor] The color of the navigation bar/container.\n *@param [contentColor] The color of the content.\n *@param [containerShape] The shape of the navigation bar.\n *@param [selectedItem] The index of currently selected item.\n *@param [itemSize] The count of items that will be shown in bottom bar.\n *@param [indicatorStyle] The type of indicator that need to be shown. Select from [IndicatorStyle]\n *@param [indicatorColor] The color to be applied on the indicator.\n *@param [indicatorHeight] The height of the indicator - `applicable only for line indicator`.\n *@param [animationSpec] The animation that will be applied to tab indicators when offset changes.\n *@param [indicatorDirection] The direction where indicator need to be placed. Select from [IndicatorDirection]\n *@param [indicatorShape] The shape to be applied on the indicator.\n *@param [content] The composable content of the navigation bar.\n */\n@Composable\nfun AnimatedBottomBar(\n    modifier: Modifier = Modifier,\n    bottomBarHeight: Dp = 64.dp,\n    containerColor: Color = MaterialTheme.colorScheme.primaryContainer,\n    contentColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    containerShape: Shape = RectangleShape,\n    selectedItem: Int? = null,\n    itemSize: Int? = null,\n    indicatorStyle: IndicatorStyle = IndicatorStyle.NONE,\n    indicatorColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    indicatorHeight: Dp = DEFAULT_INDICATOR_HEIGHT,\n    animationSpec: AnimationSpec<Dp> =\n        spring(\n            dampingRatio = 1f,\n            stiffness = Spring.StiffnessMediumLow,\n        ),\n    indicatorDirection: IndicatorDirection = IndicatorDirection.TOP,\n    indicatorShape: RoundedCornerShape = RoundedCornerShape(25.dp),\n    content: @Composable RowScope.() -> Unit,\n) {\n    Surface(\n        color = containerColor,\n        contentColor = contentColor,\n        modifier = modifier,\n        shape = containerShape,\n    ) {\n        BoxWithConstraints(\n            modifier =\n                Modifier\n                    .fillMaxWidth()\n                    .padding(horizontal = Dp(bottomBarHeight / (bottomBarHeight / 16))),\n        ) {\n            selectedItem?.let {\n                itemSize?.let {\n                    val maxWidth = this.maxWidth\n                    val indicatorOffset: Dp by animateDpAsState(\n                        targetValue =\n                            (\n                                maxWidth / (\n                                    itemSize.takeIf { it != 0 }\n                                        ?: 1\n                                )\n                            ) * selectedItem,\n                        animationSpec = animationSpec,\n                        label = \"indicator\",\n                    )\n\n                    when (indicatorStyle) {\n                        IndicatorStyle.NONE -> {}\n                        IndicatorStyle.DOT -> {\n                            DotIndicator(\n                                indicatorOffset = indicatorOffset,\n                                arraySize = itemSize.takeIf { it != 0 } ?: 1,\n                                indicatorColor = indicatorColor,\n                                modifier =\n                                    Modifier\n                                        .height(bottomBarHeight),\n                            )\n                        }\n\n                        IndicatorStyle.WORM -> {\n                            WormIndicator(\n                                indicatorOffset = indicatorOffset,\n                                indicatorColor = indicatorColor,\n                                modifier =\n                                    Modifier\n                                        .height(bottomBarHeight),\n                                itemWidth = maxWidth / (itemSize.takeIf { it != 0 } ?: 1),\n                            )\n                        }\n\n                        IndicatorStyle.LINE -> {\n                            LineIndicator(\n                                indicatorOffset = indicatorOffset,\n                                arraySize = itemSize.takeIf { it != 0 } ?: 1,\n                                indicatorHeight = indicatorHeight,\n                                indicatorColor = indicatorColor,\n                                modifier =\n                                    Modifier\n                                        .conditional(indicatorDirection == IndicatorDirection.TOP) {\n                                            align(Alignment.TopStart)\n                                        }\n                                        .conditional(indicatorDirection == IndicatorDirection.BOTTOM) {\n                                            align(Alignment.BottomStart)\n                                        },\n                                indicatorShape = indicatorShape,\n                            )\n                        }\n\n                        IndicatorStyle.FILLED -> {\n                            FilledIndicator(\n                                indicatorOffset = indicatorOffset,\n                                arraySize = itemSize.takeIf { it != 0 } ?: 1,\n                                indicatorColor = indicatorColor,\n                                modifier =\n                                    Modifier\n                                        .height(bottomBarHeight),\n                                indicatorShape = indicatorShape,\n                            )\n                        }\n                    }\n                }\n            }\n\n            Row(\n                modifier =\n                    Modifier\n                        .fillMaxWidth()\n                        .height(bottomBarHeight)\n                        .selectableGroup(),\n                horizontalArrangement = Arrangement.SpaceBetween,\n                content = content,\n            )\n        }\n    }\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/components/BottomBarItem.kt",
    "content": "package com.example.bottombar.components\n\nimport androidx.compose.foundation.layout.RowScope\nimport androidx.compose.material3.MaterialTheme\nimport androidx.compose.runtime.Composable\nimport androidx.compose.ui.Modifier\nimport androidx.compose.ui.graphics.Brush\nimport androidx.compose.ui.graphics.Color\nimport androidx.compose.ui.graphics.vector.ImageVector\nimport androidx.compose.ui.graphics.vector.rememberVectorPainter\nimport com.example.bottombar.model.ItemStyle\nimport com.example.bottombar.model.VisibleItem\n\n/**\n * A composable function that creates view for navigation items according to provided item style.\n *  @param [modifier] Modifier to be applied to the navigation bar.\n *  @param [selected] The index of the currently selected item.\n *  @param [onClick] The handler that will be invoked when user clicks on bottom bar item.\n *  @param [imageVector] The image vector that will be used to show item icon.\n *  @param [containerColor] The color to be applied on the container.\n *  @param [contentColor] The color to be applied on the content.\n *  @param [iconColor] The color to be applied on the icon.\n *  @param [textColor] The color to be applied on the text.\n *  @param [activeIndicatorColor] The color to be applied on the indicator when its selected/active. Applicable only for [ItemStyle.STYLE2]\n *  @param [inactiveIndicatorColor]  The color to be applied on the indicator when its inactive. Applicable only for [ItemStyle.STYLE2]\n *  @param [glowingBackground] The glowing background which will be applied behind image. Applicable only for [ItemStyle.STYLE5]\n *  @param [label] The text to be shown on bottom bar.\n *  @param [visibleItem] The item(either LABEL/ICON) that need to be shown when it is selected. Select from [VisibleItem]\n *  @param [itemStyle] The style to be applied on bottom bar items. Select from [ItemStyle]\n */\n@Composable\nfun RowScope.BottomBarItem(\n    modifier: Modifier = Modifier,\n    selected: Boolean,\n    onClick: () -> Unit,\n    imageVector: ImageVector,\n    containerColor: Color = Color.Transparent,\n    contentColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    iconColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    textColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    activeIndicatorColor: Color = MaterialTheme.colorScheme.onPrimaryContainer.copy(0.2f),\n    inactiveIndicatorColor: Color = Color.Transparent,\n    glowingBackground: Brush =\n        Brush.radialGradient(\n            listOf(\n                Color.White,\n                Color.Transparent,\n                Color.Transparent,\n            ),\n        ),\n    label: String,\n    visibleItem: VisibleItem = VisibleItem.ICON,\n    itemStyle: ItemStyle = ItemStyle.STYLE1,\n) {\n    when (itemStyle) {\n        ItemStyle.STYLE1 -> {\n            NavigationBarItem(\n                modifier,\n                selected,\n                onClick,\n                rememberVectorPainter(image = imageVector),\n                containerColor,\n                contentColor,\n                iconColor,\n                textColor,\n                label,\n                visibleItem,\n            )\n        }\n\n        ItemStyle.STYLE2 -> {\n            NavigationBarItem(\n                modifier,\n                selected,\n                onClick,\n                rememberVectorPainter(image = imageVector),\n                contentColor,\n                iconColor,\n                textColor,\n                label,\n                activeIndicatorColor,\n                inactiveIndicatorColor,\n            )\n        }\n\n        ItemStyle.STYLE3 -> {\n            NavigationBarItem(\n                modifier,\n                selected,\n                onClick,\n                rememberVectorPainter(image = imageVector),\n                containerColor,\n                contentColor,\n                iconColor,\n                textColor,\n                label,\n            )\n        }\n\n        ItemStyle.STYLE4 -> {\n            NavigationBarItem(\n                modifier,\n                selected,\n                onClick,\n                rememberVectorPainter(image = imageVector),\n                containerColor,\n                contentColor,\n                iconColor,\n            )\n        }\n\n        ItemStyle.STYLE5 -> {\n            NavigationBarItem(\n                modifier,\n                selected,\n                onClick,\n                rememberVectorPainter(image = imageVector),\n                containerColor,\n                contentColor,\n                iconColor,\n                glowingBackground = glowingBackground,\n            )\n        }\n    }\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/components/Indicators.kt",
    "content": "package com.example.bottombar.components\n\nimport androidx.compose.foundation.background\nimport androidx.compose.foundation.layout.Box\nimport androidx.compose.foundation.layout.Column\nimport androidx.compose.foundation.layout.Spacer\nimport androidx.compose.foundation.layout.fillMaxWidth\nimport androidx.compose.foundation.layout.height\nimport androidx.compose.foundation.layout.offset\nimport androidx.compose.foundation.layout.padding\nimport androidx.compose.foundation.layout.size\nimport androidx.compose.foundation.layout.width\nimport androidx.compose.foundation.shape.RoundedCornerShape\nimport androidx.compose.material3.Icon\nimport androidx.compose.runtime.Composable\nimport androidx.compose.ui.Alignment\nimport androidx.compose.ui.Modifier\nimport androidx.compose.ui.draw.clip\nimport androidx.compose.ui.graphics.Color\nimport androidx.compose.ui.res.painterResource\nimport androidx.compose.ui.unit.Dp\nimport androidx.compose.ui.unit.dp\nimport com.example.bottombar.R\nimport com.example.bottombar.utils.customWormTransition\n\n@Composable\ninternal fun LineIndicator(\n    indicatorOffset: Dp,\n    arraySize: Int,\n    indicatorColor: Color,\n    indicatorHeight: Dp,\n    modifier: Modifier,\n    indicatorShape: RoundedCornerShape,\n) {\n    Box(\n        modifier =\n            modifier\n                .height(indicatorHeight)\n                .fillMaxWidth(1f / arraySize)\n                .offset(\n                    x = indicatorOffset,\n                )\n                .clip(shape = indicatorShape)\n                .background(indicatorColor, shape = indicatorShape),\n    )\n}\n\n@Composable\ninternal fun DotIndicator(\n    indicatorOffset: Dp,\n    arraySize: Int,\n    indicatorColor: Color,\n    modifier: Modifier,\n) {\n    Box(\n        modifier =\n            modifier\n                .fillMaxWidth(1f / arraySize)\n                .offset(\n                    x = indicatorOffset,\n                ),\n    ) {\n        Column(modifier = Modifier.align(Alignment.BottomCenter)) {\n            Icon(\n                painter = painterResource(id = R.drawable.ic_dot_indicator),\n                contentDescription = \"\",\n                tint = indicatorColor,\n                modifier =\n                    Modifier\n                        .size(8.dp),\n            )\n            Spacer(modifier = Modifier.height(4.dp))\n        }\n    }\n}\n\n@Composable\ninternal fun WormIndicator(\n    indicatorOffset: Dp,\n    indicatorColor: Color,\n    modifier: Modifier,\n    itemWidth: Dp,\n) {\n    Box(\n        modifier =\n            modifier\n                .width(itemWidth),\n    ) {\n        Box(\n            modifier =\n                Modifier\n                    .align(Alignment.BottomCenter)\n                    .padding(bottom = 4.dp)\n                    .customWormTransition(indicatorOffset, indicatorColor, itemWidth)\n                    .size(8.dp),\n        )\n    }\n}\n\n@Composable\ninternal fun FilledIndicator(\n    indicatorOffset: Dp,\n    arraySize: Int,\n    indicatorColor: Color,\n    modifier: Modifier,\n    indicatorShape: RoundedCornerShape,\n) {\n    Box(\n        modifier =\n            modifier\n                .fillMaxWidth(1f / arraySize)\n                .offset(\n                    x = indicatorOffset,\n                )\n                .padding(vertical = 8.dp)\n                .clip(indicatorShape)\n                .background(indicatorColor, shape = indicatorShape),\n    )\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/components/NavigationBarItem.kt",
    "content": "package com.example.bottombar.components\n\nimport androidx.compose.animation.AnimatedVisibility\nimport androidx.compose.animation.animateColorAsState\nimport androidx.compose.animation.core.LinearEasing\nimport androidx.compose.animation.core.animateDpAsState\nimport androidx.compose.animation.core.animateFloatAsState\nimport androidx.compose.animation.core.tween\nimport androidx.compose.animation.fadeIn\nimport androidx.compose.animation.fadeOut\nimport androidx.compose.animation.slideInVertically\nimport androidx.compose.animation.slideOutVertically\nimport androidx.compose.foundation.background\nimport androidx.compose.foundation.clickable\nimport androidx.compose.foundation.interaction.MutableInteractionSource\nimport androidx.compose.foundation.layout.Arrangement\nimport androidx.compose.foundation.layout.Box\nimport androidx.compose.foundation.layout.BoxWithConstraints\nimport androidx.compose.foundation.layout.Column\nimport androidx.compose.foundation.layout.Row\nimport androidx.compose.foundation.layout.RowScope\nimport androidx.compose.foundation.layout.fillMaxHeight\nimport androidx.compose.foundation.layout.fillMaxSize\nimport androidx.compose.foundation.layout.height\nimport androidx.compose.foundation.layout.padding\nimport androidx.compose.foundation.shape.RoundedCornerShape\nimport androidx.compose.material.ripple.rememberRipple\nimport androidx.compose.material3.Icon\nimport androidx.compose.material3.MaterialTheme\nimport androidx.compose.material3.Surface\nimport androidx.compose.material3.Text\nimport androidx.compose.runtime.Composable\nimport androidx.compose.runtime.LaunchedEffect\nimport androidx.compose.runtime.getValue\nimport androidx.compose.runtime.mutableStateOf\nimport androidx.compose.runtime.remember\nimport androidx.compose.runtime.setValue\nimport androidx.compose.ui.Alignment\nimport androidx.compose.ui.Modifier\nimport androidx.compose.ui.draw.alpha\nimport androidx.compose.ui.draw.scale\nimport androidx.compose.ui.graphics.Brush\nimport androidx.compose.ui.graphics.Color\nimport androidx.compose.ui.graphics.painter.Painter\nimport androidx.compose.ui.text.style.TextOverflow\nimport androidx.compose.ui.unit.Dp\nimport androidx.compose.ui.unit.dp\nimport androidx.compose.ui.unit.sp\nimport com.example.bottombar.model.AnimationState\nimport com.example.bottombar.model.VisibleItem\nimport com.example.bottombar.utils.DefaultAlpha\nimport com.example.bottombar.utils.DefaultScale\nimport com.example.bottombar.utils.LargeScale\nimport com.example.bottombar.utils.LongDuration\nimport com.example.bottombar.utils.LowestAlpha\nimport com.example.bottombar.utils.MediumDuration\nimport com.example.bottombar.utils.ShortDuration\nimport com.example.bottombar.utils.SmallScale\n\n/**\n * A composable function that creates view for **STYLE1** where selected item will\n * change on the basis of value provided in `visibleItem`\n */\n@Composable\ninternal fun RowScope.NavigationBarItem(\n    modifier: Modifier = Modifier,\n    selected: Boolean,\n    onClick: () -> Unit,\n    iconPainter: Painter,\n    containerColor: Color = MaterialTheme.colorScheme.primaryContainer,\n    contentColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    iconColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    textColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    label: String,\n    visibleItem: VisibleItem = VisibleItem.LABEL,\n) {\n    var animationState by remember { mutableStateOf(AnimationState.Start) }\n    val scaleAnimation: Float by animateFloatAsState(\n        if (animationState == AnimationState.Start) DefaultScale else SmallScale,\n        tween(easing = LinearEasing),\n        label = \"\",\n    )\n\n    LaunchedEffect(key1 = selected, key2 = Unit, block = {\n        animationState =\n            if (selected && visibleItem == VisibleItem.BOTH) AnimationState.Finish else AnimationState.Start\n    })\n\n    Surface(\n        color = containerColor,\n        contentColor = contentColor,\n        modifier =\n            Modifier\n                .weight(1f)\n                .clickable(\n                    onClick = {\n                        onClick()\n                    },\n                    interactionSource = remember { MutableInteractionSource() },\n                    indication = rememberRipple(bounded = false, radius = 30.dp),\n                ),\n    ) {\n        Column(\n            modifier =\n                modifier\n                    .fillMaxHeight()\n                    .scale(scaleAnimation),\n            horizontalAlignment = Alignment.CenterHorizontally,\n            verticalArrangement = Arrangement.Center,\n        ) {\n            AnimatedVisibility(\n                visible = (visibleItem == VisibleItem.BOTH && !selected),\n                enter =\n                    fadeIn() +\n                        slideInVertically(\n                            tween(easing = LinearEasing),\n                        ) { fullHeight -> -fullHeight },\n                exit =\n                    slideOutVertically(\n                        tween(easing = LinearEasing),\n                    ) { fullHeight -> -fullHeight } + fadeOut(),\n            ) {\n                Icon(\n                    painter = iconPainter,\n                    contentDescription = null,\n                    tint = iconColor,\n                )\n            }\n\n            AnimatedVisibility(\n                visible = (visibleItem == VisibleItem.BOTH && selected),\n                enter =\n                    fadeIn() +\n                        slideInVertically(\n                            tween(easing = LinearEasing),\n                        ) { fullHeight -> fullHeight },\n                exit =\n                    slideOutVertically(\n                        tween(easing = LinearEasing),\n                    ) { fullHeight -> fullHeight } + fadeOut(),\n            ) {\n                Column(horizontalAlignment = Alignment.CenterHorizontally) {\n                    Icon(\n                        painter = iconPainter,\n                        contentDescription = null,\n                        tint = iconColor,\n                    )\n\n                    Text(\n                        text = label,\n                        color = textColor,\n                        style = MaterialTheme.typography.labelMedium,\n                        maxLines = 1,\n                        softWrap = false,\n                        overflow = TextOverflow.Clip,\n                    )\n                }\n            }\n\n            if (visibleItem == VisibleItem.BOTH) return@Surface\n\n            AnimatedVisibility(\n                visible = if (visibleItem == VisibleItem.LABEL) !selected else selected,\n                enter =\n                    fadeIn() +\n                        slideInVertically(\n                            tween(\n                                easing = LinearEasing,\n                            ),\n                        ) { fullHeight -> -fullHeight },\n                exit =\n                    slideOutVertically(\n                        tween(\n                            easing = LinearEasing,\n                        ),\n                    ) { fullHeight -> -fullHeight } + fadeOut(),\n            ) {\n                Icon(\n                    painter = iconPainter,\n                    contentDescription = null,\n                    tint = iconColor,\n                )\n            }\n\n            AnimatedVisibility(\n                visible = if (visibleItem == VisibleItem.LABEL) selected else !selected,\n                enter =\n                    fadeIn() +\n                        slideInVertically(\n                            tween(\n                                easing = LinearEasing,\n                            ),\n                        ) { fullHeight -> fullHeight },\n                exit =\n                    slideOutVertically(\n                        tween(\n                            easing = LinearEasing,\n                        ),\n                    ) { fullHeight -> fullHeight } + fadeOut(),\n            ) {\n                Text(\n                    text = label,\n                    color = textColor,\n                    style = MaterialTheme.typography.labelMedium,\n                    maxLines = 1,\n                    softWrap = false,\n                    overflow = TextOverflow.Clip,\n                )\n            }\n        }\n    }\n}\n\n/**\n * A composable function that creates view for **STYLE2** where selected item will\n * have **FILLED** indicators and horizontal item placement\n */\n@Composable\ninternal fun NavigationBarItem(\n    modifier: Modifier,\n    selected: Boolean,\n    onClick: () -> Unit,\n    iconPainter: Painter,\n    contentColor: Color,\n    iconColor: Color,\n    textColor: Color,\n    label: String,\n    activeIndicatorColor: Color,\n    inactiveIndicatorColor: Color,\n) {\n    val color by animateColorAsState(\n        targetValue = if (selected) activeIndicatorColor else inactiveIndicatorColor,\n        animationSpec = tween(easing = LinearEasing),\n        label = \"\",\n    )\n\n    BoxWithConstraints(\n        modifier =\n            modifier\n                .fillMaxHeight(),\n        contentAlignment = Alignment.Center,\n    ) {\n        Surface(\n            color = color,\n            contentColor = contentColor,\n            shape = RoundedCornerShape(maxHeight / 2),\n            modifier =\n                Modifier.clickable(\n                    interactionSource = remember { MutableInteractionSource() },\n                    indication = rememberRipple(bounded = false, radius = 30.dp),\n                ) { onClick() },\n        ) {\n            Row(\n                modifier =\n                    Modifier\n                        .padding(\n                            vertical = maxHeight / 12,\n                            horizontal = maxHeight / 4,\n                        ),\n                horizontalArrangement = Arrangement.Center,\n                verticalAlignment = Alignment.CenterVertically,\n            ) {\n                Icon(\n                    modifier = Modifier.height(this@BoxWithConstraints.maxHeight / 2),\n                    painter = iconPainter,\n                    contentDescription = null,\n                    tint = iconColor,\n                )\n                AnimatedVisibility(\n                    visible = selected,\n                ) {\n                    Text(\n                        text = label,\n                        color = textColor,\n                        style = MaterialTheme.typography.labelMedium,\n                        maxLines = 1,\n                        softWrap = false,\n                        overflow = TextOverflow.Clip,\n                        modifier = Modifier.padding(horizontal = 4.dp),\n                    )\n                }\n            }\n        }\n    }\n}\n\n/**\n * A composable function that creates view for **STYLE3** where selected item will\n * have `scale animation` and vertical item placement\n */\n@Composable\ninternal fun RowScope.NavigationBarItem(\n    modifier: Modifier = Modifier,\n    selected: Boolean,\n    onClick: () -> Unit,\n    iconPainter: Painter,\n    containerColor: Color = MaterialTheme.colorScheme.primaryContainer,\n    contentColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    iconColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    textColor: Color = MaterialTheme.colorScheme.onPrimaryContainer,\n    label: String,\n) {\n    var animationState by remember { mutableStateOf(AnimationState.Start) }\n    val scaleAnimation: Float by animateFloatAsState(\n        if (animationState == AnimationState.Start) DefaultScale else SmallScale,\n        tween(durationMillis = LongDuration, delayMillis = ShortDuration, easing = LinearEasing),\n        label = \"\",\n    )\n    val alphaAnimation: Float by animateFloatAsState(\n        if (animationState == AnimationState.Start) LowestAlpha else DefaultAlpha,\n        tween(\n            durationMillis = if (animationState == AnimationState.Start) MediumDuration else LongDuration,\n            delayMillis = if (animationState == AnimationState.Start) 0 else ShortDuration,\n            easing = LinearEasing,\n        ),\n        label = \"\",\n    )\n    val paddingAnimation: Dp by animateDpAsState(\n        if (animationState == AnimationState.Start) 20.dp else 16.dp,\n        tween(durationMillis = LongDuration, delayMillis = ShortDuration, easing = LinearEasing),\n        label = \"\",\n    )\n    LaunchedEffect(key1 = selected, key2 = Unit, block = {\n        animationState = if (selected) AnimationState.Finish else AnimationState.Start\n    })\n\n    Surface(\n        color = containerColor,\n        contentColor = contentColor,\n        modifier =\n            Modifier\n                .clickable(\n                    onClick = {\n                        onClick()\n                    },\n                    interactionSource = remember { MutableInteractionSource() },\n                    indication = rememberRipple(bounded = false, radius = 30.dp),\n                )\n                .weight(1f),\n    ) {\n        Box(\n            modifier =\n                modifier\n                    .fillMaxHeight(),\n            contentAlignment = Alignment.TopCenter,\n        ) {\n            Icon(\n                painter = iconPainter,\n                contentDescription = null,\n                tint = iconColor,\n                modifier =\n                    Modifier\n                        .scale(scaleAnimation)\n                        .padding(top = paddingAnimation),\n            )\n\n            Text(\n                text = label,\n                color = textColor,\n                fontSize = 10.sp,\n                maxLines = 1,\n                softWrap = false,\n                overflow = TextOverflow.Clip,\n                modifier =\n                    Modifier\n                        .align(Alignment.BottomCenter)\n                        .alpha(alphaAnimation)\n                        .padding(bottom = 12.dp),\n            )\n        }\n    }\n}\n\n/**\n * A composable function that creates view for **STYLE4** where selected item will\n * have active color and rest all will be grayed out.\n */\n@Composable\ninternal fun RowScope.NavigationBarItem(\n    modifier: Modifier,\n    selected: Boolean,\n    onClick: () -> Unit,\n    iconPainter: Painter,\n    containerColor: Color,\n    contentColor: Color,\n    iconColor: Color,\n) {\n    var animationState by remember { mutableStateOf(AnimationState.Start) }\n    val scaleAnimation: Float by animateFloatAsState(\n        if (animationState == AnimationState.Start) DefaultScale else LargeScale,\n        tween(durationMillis = MediumDuration, delayMillis = ShortDuration, easing = LinearEasing),\n        label = \"\",\n    )\n\n    val color by animateColorAsState(\n        targetValue = if (selected) iconColor else iconColor.copy(0.5f),\n        animationSpec = tween(easing = LinearEasing),\n        label = \"\",\n    )\n\n    LaunchedEffect(key1 = selected, key2 = Unit, block = {\n        animationState = if (selected) AnimationState.Finish else AnimationState.Start\n    })\n\n    Surface(\n        color = containerColor,\n        contentColor = contentColor,\n        modifier =\n            Modifier\n                .clickable(\n                    onClick = {\n                        onClick()\n                    },\n                    interactionSource = remember { MutableInteractionSource() },\n                    indication = rememberRipple(bounded = false, radius = 30.dp),\n                )\n                .weight(1f),\n    ) {\n        Box(\n            modifier =\n                modifier\n                    .fillMaxHeight()\n                    .scale(scaleAnimation),\n            contentAlignment = Alignment.Center,\n        ) {\n            Icon(\n                painter = iconPainter,\n                contentDescription = null,\n                tint = color,\n            )\n        }\n    }\n}\n\n/**\n * A composable function that creates view for **STYLE5** where selected item will\n * have active color with glowing background.\n */\n@Composable\ninternal fun RowScope.NavigationBarItem(\n    modifier: Modifier,\n    selected: Boolean,\n    onClick: () -> Unit,\n    iconPainter: Painter,\n    containerColor: Color,\n    contentColor: Color,\n    iconColor: Color,\n    glowingBackground: Brush,\n) {\n    var animationState by remember { mutableStateOf(AnimationState.Start) }\n    val scaleAnimation: Float by animateFloatAsState(\n        if (animationState == AnimationState.Start) LowestAlpha else DefaultAlpha,\n        tween(durationMillis = MediumDuration, delayMillis = ShortDuration, easing = LinearEasing),\n        label = \"\",\n    )\n\n    LaunchedEffect(key1 = selected, key2 = Unit, block = {\n        animationState = if (selected) AnimationState.Finish else AnimationState.Start\n    })\n\n    Surface(\n        color = containerColor,\n        contentColor = contentColor,\n        modifier =\n            Modifier\n                .clickable(\n                    onClick = {\n                        onClick()\n                    },\n                    interactionSource = remember { MutableInteractionSource() },\n                    indication = rememberRipple(bounded = false, radius = 30.dp),\n                )\n                .weight(1f),\n    ) {\n        Box(\n            modifier =\n                modifier\n                    .fillMaxHeight(),\n            contentAlignment = Alignment.Center,\n        ) {\n            if (selected) {\n                Box(\n                    modifier =\n                        Modifier\n                            .fillMaxSize()\n                            .scale(scaleAnimation)\n                            .background(glowingBackground),\n                )\n            }\n\n            Icon(\n                painter = iconPainter,\n                contentDescription = null,\n                tint = iconColor,\n            )\n        }\n    }\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/model/AnimationState.kt",
    "content": "package com.example.bottombar.model\n\ninternal enum class AnimationState {\n    Start,\n    Finish,\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/model/IndicatorDirection.kt",
    "content": "package com.example.bottombar.model\n\n/**\n * Indicates the direction where indicator need to be placed.\n *\n * [TOP]: Indicator will be placed at Top direction.\n *\n * [BOTTOM]: Indicator will be placed at Bottom direction.\n *\n */\nenum class IndicatorDirection {\n    TOP,\n    BOTTOM,\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/model/IndicatorStyle.kt",
    "content": "package com.example.bottombar.model\n\n/**\n * Indicates which type of indicator should be shown.\n *\n * [NONE]: No indicator will be shown.\n *\n * [DOT]: Dot indicator will be shown(only at bottom direction).\n *\n * [WORM]: Worm indicator will be shown(only at bottom direction).\n *\n * [LINE]: Line indicator(Horizontal Tab) will be shown at specified direction.\n *\n * [FILLED]: Rounded indicator(Filled) will be shown at center of bottom bar.\n */\nenum class IndicatorStyle {\n    NONE,\n    DOT,\n    WORM,\n    LINE,\n    FILLED,\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/model/ItemStyle.kt",
    "content": "package com.example.bottombar.model\n\n/**\n *[STYLE1]: Any 1 item(either Icon or Label) will be visible at a time or both items can be visible\n *  at a time with slide-in & slide-out animation.\n *\n *[STYLE2]: Both items will be visible at a time with horizontal arrangement if it\n *  is currently selected with [IndicatorStyle.FILLED] as default indicator. (**NOTE:-** While using [STYLE2],\n *  make sure that indicatorStyle is [IndicatorStyle.NONE] in **AnimatedBottomBar**)\n *\n *[STYLE3]: Both items will be visible at a time with vertical arrangement and scaling animation if it\n *  is currently selected.\n *\n *[STYLE4]: Only Icon will be visible at a time with scale animation and\n * only selected icon will have icon-color and others as grayed out.\n *\n *[STYLE5]: Only Icon will be visible at a time with glowing background for selected item.\n *\n */\nenum class ItemStyle {\n    STYLE1,\n    STYLE2,\n    STYLE3,\n    STYLE4,\n    STYLE5,\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/model/VisibleItem.kt",
    "content": "package com.example.bottombar.model\n\n/**\n * Indicates which thing will be visible when an item is selected.\n *\n * **[VisibleItem] will be applicable only for [ItemStyle.STYLE1]**\n *\n * [ICON]: Icon will be visible for selected item and Label for others.\n *\n * [LABEL]: Label will be visible for selected item and Icon for others.\n *\n * [BOTH]: Both Icon & Label will be visible for selected Item & only Icon for others.\n */\nenum class VisibleItem {\n    ICON,\n    LABEL,\n    BOTH,\n}\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/utils/Constants.kt",
    "content": "package com.example.bottombar.utils\n\n// For Scaling Animations\nconst val LargeScale = 1.2f\nconst val DefaultScale = 1f\nconst val SmallScale = 0.8f\n\n// For Alpha Animations\nconst val DefaultAlpha = 1f\nconst val LowestAlpha = 0f\n\n// For Animation Durations\nconst val LongDuration = 600\nconst val MediumDuration = 300\nconst val ShortDuration = 100\n"
  },
  {
    "path": "bottombar/src/main/java/com/example/bottombar/utils/ModifierExtensions.kt",
    "content": "package com.example.bottombar.utils\n\nimport androidx.compose.runtime.Composable\nimport androidx.compose.ui.Modifier\nimport androidx.compose.ui.composed\nimport androidx.compose.ui.draw.drawWithContent\nimport androidx.compose.ui.geometry.CornerRadius\nimport androidx.compose.ui.geometry.RoundRect\nimport androidx.compose.ui.graphics.Color\nimport androidx.compose.ui.graphics.Path\nimport androidx.compose.ui.unit.Dp\n\ninternal fun Modifier.conditional(\n    condition: Boolean,\n    orElse: (@Composable Modifier.() -> Modifier)? = null,\n    modifier: @Composable Modifier.() -> Modifier,\n): Modifier =\n    composed {\n        if (condition) {\n            modifier.invoke(this)\n        } else {\n            orElse?.invoke(this) ?: this\n        }\n    }\n\ninternal fun Modifier.customWormTransition(\n    offset: Dp,\n    indicatorColor: Color,\n    itemWidth: Dp,\n) = composed {\n    drawWithContent {\n        val distance = itemWidth.roundToPx()\n        val scrollPosition = (offset.toPx().div(distance))\n        val wormOffset = (scrollPosition % 1) * 2\n\n        val xPos = scrollPosition.toInt() * distance\n        val head = xPos + distance * 0f.coerceAtLeast(wormOffset - 1)\n        val tail = xPos + size.width + distance * 1f.coerceAtMost(wormOffset)\n\n        val worm =\n            RoundRect(\n                head,\n                0f,\n                tail,\n                size.height,\n                CornerRadius(50f),\n            )\n\n        val path = Path().apply { addRoundRect(worm) }\n\n        // Draw the worm shape on top of the content\n        drawPath(path = path, color = indicatorColor)\n    }\n}\n"
  },
  {
    "path": "bottombar/src/main/res/drawable/ic_dot_indicator.xml",
    "content": "<vector xmlns:android=\"http://schemas.android.com/apk/res/android\"\n    android:width=\"12dp\"\n    android:height=\"12dp\"\n    android:tint=\"#000000\"\n    android:viewportWidth=\"24\"\n    android:viewportHeight=\"24\">\n    <path\n        android:fillColor=\"@android:color/white\"\n        android:pathData=\"M12,2C6.47,2 2,6.47 2,12s4.47,10 10,10 10,-4.47 10,-10S17.53,2 12,2z\" />\n</vector>\n"
  },
  {
    "path": "bottombar/src/test/java/com/example/bottombar/ExampleUnitTest.kt",
    "content": "package com.example.bottombar\n\nimport org.junit.Assert.assertEquals\nimport org.junit.Test\n\n/**\n * Example local unit test, which will execute on the development machine (host).\n *\n * See [testing documentation](http://d.android.com/tools/testing).\n */\nclass ExampleUnitTest {\n    @Test\n    fun addition_isCorrect() {\n        assertEquals(4, 2 + 2)\n    }\n}\n"
  },
  {
    "path": "build.gradle.kts",
    "content": "// Top-level build file where you can add configuration options common to all sub-projects/modules.\nplugins {\n    id(\"com.android.application\") version \"8.4.1\" apply false\n    id(\"org.jetbrains.kotlin.android\") version \"1.9.10\" apply false\n    id(\"com.android.library\") version \"8.4.1\" apply false\n    id(\"io.github.gradle-nexus.publish-plugin\") version \"1.3.0\"\n}\n\napply {\n    from(\"$rootDir/scripts/publish-root.gradle\")\n}\n"
  },
  {
    "path": "gradle/wrapper/gradle-wrapper.properties",
    "content": "#Wed Sep 27 17:49:33 IST 2023\ndistributionBase=GRADLE_USER_HOME\ndistributionPath=wrapper/dists\ndistributionUrl=https\\://services.gradle.org/distributions/gradle-8.6-bin.zip\nzipStoreBase=GRADLE_USER_HOME\nzipStorePath=wrapper/dists\n"
  },
  {
    "path": "gradle.properties",
    "content": "# Project-wide Gradle settings.\n# IDE (e.g. Android Studio) users:\n# Gradle settings configured through the IDE *will override*\n# any settings specified in this file.\n# For more details on how to configure your build environment visit\n# http://www.gradle.org/docs/current/userguide/build_environment.html\n# Specifies the JVM arguments used for the daemon process.\n# The setting is particularly useful for tweaking memory settings.\norg.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8\n# When configured, Gradle will run in incubating parallel mode.\n# This option should only be used with decoupled projects. More details, visit\n# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects\n# org.gradle.parallel=true\n# AndroidX package structure to make it clearer which packages are bundled with the\n# Android operating system, and which are packaged with your app's APK\n# https://developer.android.com/topic/libraries/support-library/androidx-rn\nandroid.useAndroidX=true\n# Kotlin code style for this project: \"official\" or \"obsolete\":\nkotlin.code.style=official\n# Enables namespacing of each library's R class so that its R class includes only the\n# resources declared in the library itself and none from the library's dependencies,\n# thereby reducing the size of the R class for that library\nandroid.nonTransitiveRClass=true\n"
  },
  {
    "path": "gradlew",
    "content": "#!/usr/bin/env sh\n\n#\n# Copyright 2015 the original author or authors.\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n#      https://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n#\n\n##############################################################################\n##\n##  Gradle start up script for UN*X\n##\n##############################################################################\n\n# Attempt to set APP_HOME\n# Resolve links: $0 may be a link\nPRG=\"$0\"\n# Need this for relative symlinks.\nwhile [ -h \"$PRG\" ] ; do\n    ls=`ls -ld \"$PRG\"`\n    link=`expr \"$ls\" : '.*-> \\(.*\\)$'`\n    if expr \"$link\" : '/.*' > /dev/null; then\n        PRG=\"$link\"\n    else\n        PRG=`dirname \"$PRG\"`\"/$link\"\n    fi\ndone\nSAVED=\"`pwd`\"\ncd \"`dirname \\\"$PRG\\\"`/\" >/dev/null\nAPP_HOME=\"`pwd -P`\"\ncd \"$SAVED\" >/dev/null\n\nAPP_NAME=\"Gradle\"\nAPP_BASE_NAME=`basename \"$0\"`\n\n# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.\nDEFAULT_JVM_OPTS='\"-Xmx64m\" \"-Xms64m\"'\n\n# Use the maximum available, or set MAX_FD != -1 to use that value.\nMAX_FD=\"maximum\"\n\nwarn () {\n    echo \"$*\"\n}\n\ndie () {\n    echo\n    echo \"$*\"\n    echo\n    exit 1\n}\n\n# OS specific support (must be 'true' or 'false').\ncygwin=false\nmsys=false\ndarwin=false\nnonstop=false\ncase \"`uname`\" in\n  CYGWIN* )\n    cygwin=true\n    ;;\n  Darwin* )\n    darwin=true\n    ;;\n  MINGW* )\n    msys=true\n    ;;\n  NONSTOP* )\n    nonstop=true\n    ;;\nesac\n\nCLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar\n\n\n# Determine the Java command to use to start the JVM.\nif [ -n \"$JAVA_HOME\" ] ; then\n    if [ -x \"$JAVA_HOME/jre/sh/java\" ] ; then\n        # IBM's JDK on AIX uses strange locations for the executables\n        JAVACMD=\"$JAVA_HOME/jre/sh/java\"\n    else\n        JAVACMD=\"$JAVA_HOME/bin/java\"\n    fi\n    if [ ! -x \"$JAVACMD\" ] ; then\n        die \"ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME\n\nPlease set the JAVA_HOME variable in your environment to match the\nlocation of your Java installation.\"\n    fi\nelse\n    JAVACMD=\"java\"\n    which java >/dev/null 2>&1 || die \"ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.\n\nPlease set the JAVA_HOME variable in your environment to match the\nlocation of your Java installation.\"\nfi\n\n# Increase the maximum file descriptors if we can.\nif [ \"$cygwin\" = \"false\" -a \"$darwin\" = \"false\" -a \"$nonstop\" = \"false\" ] ; then\n    MAX_FD_LIMIT=`ulimit -H -n`\n    if [ $? -eq 0 ] ; then\n        if [ \"$MAX_FD\" = \"maximum\" -o \"$MAX_FD\" = \"max\" ] ; then\n            MAX_FD=\"$MAX_FD_LIMIT\"\n        fi\n        ulimit -n $MAX_FD\n        if [ $? -ne 0 ] ; then\n            warn \"Could not set maximum file descriptor limit: $MAX_FD\"\n        fi\n    else\n        warn \"Could not query maximum file descriptor limit: $MAX_FD_LIMIT\"\n    fi\nfi\n\n# For Darwin, add options to specify how the application appears in the dock\nif $darwin; then\n    GRADLE_OPTS=\"$GRADLE_OPTS \\\"-Xdock:name=$APP_NAME\\\" \\\"-Xdock:icon=$APP_HOME/media/gradle.icns\\\"\"\nfi\n\n# For Cygwin or MSYS, switch paths to Windows format before running java\nif [ \"$cygwin\" = \"true\" -o \"$msys\" = \"true\" ] ; then\n    APP_HOME=`cygpath --path --mixed \"$APP_HOME\"`\n    CLASSPATH=`cygpath --path --mixed \"$CLASSPATH\"`\n\n    JAVACMD=`cygpath --unix \"$JAVACMD\"`\n\n    # We build the pattern for arguments to be converted via cygpath\n    ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`\n    SEP=\"\"\n    for dir in $ROOTDIRSRAW ; do\n        ROOTDIRS=\"$ROOTDIRS$SEP$dir\"\n        SEP=\"|\"\n    done\n    OURCYGPATTERN=\"(^($ROOTDIRS))\"\n    # Add a user-defined pattern to the cygpath arguments\n    if [ \"$GRADLE_CYGPATTERN\" != \"\" ] ; then\n        OURCYGPATTERN=\"$OURCYGPATTERN|($GRADLE_CYGPATTERN)\"\n    fi\n    # Now convert the arguments - kludge to limit ourselves to /bin/sh\n    i=0\n    for arg in \"$@\" ; do\n        CHECK=`echo \"$arg\"|egrep -c \"$OURCYGPATTERN\" -`\n        CHECK2=`echo \"$arg\"|egrep -c \"^-\"`                                 ### Determine if an option\n\n        if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition\n            eval `echo args$i`=`cygpath --path --ignore --mixed \"$arg\"`\n        else\n            eval `echo args$i`=\"\\\"$arg\\\"\"\n        fi\n        i=`expr $i + 1`\n    done\n    case $i in\n        0) set -- ;;\n        1) set -- \"$args0\" ;;\n        2) set -- \"$args0\" \"$args1\" ;;\n        3) set -- \"$args0\" \"$args1\" \"$args2\" ;;\n        4) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" ;;\n        5) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" ;;\n        6) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" \"$args5\" ;;\n        7) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" \"$args5\" \"$args6\" ;;\n        8) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" \"$args5\" \"$args6\" \"$args7\" ;;\n        9) set -- \"$args0\" \"$args1\" \"$args2\" \"$args3\" \"$args4\" \"$args5\" \"$args6\" \"$args7\" \"$args8\" ;;\n    esac\nfi\n\n# Escape application args\nsave () {\n    for i do printf %s\\\\n \"$i\" | sed \"s/'/'\\\\\\\\''/g;1s/^/'/;\\$s/\\$/' \\\\\\\\/\" ; done\n    echo \" \"\n}\nAPP_ARGS=`save \"$@\"`\n\n# Collect all arguments for the java command, following the shell quoting and substitution rules\neval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS \"\\\"-Dorg.gradle.appname=$APP_BASE_NAME\\\"\" -classpath \"\\\"$CLASSPATH\\\"\" org.gradle.wrapper.GradleWrapperMain \"$APP_ARGS\"\n\nexec \"$JAVACMD\" \"$@\"\n"
  },
  {
    "path": "gradlew.bat",
    "content": "@rem\n@rem Copyright 2015 the original author or authors.\n@rem\n@rem Licensed under the Apache License, Version 2.0 (the \"License\");\n@rem you may not use this file except in compliance with the License.\n@rem You may obtain a copy of the License at\n@rem\n@rem      https://www.apache.org/licenses/LICENSE-2.0\n@rem\n@rem Unless required by applicable law or agreed to in writing, software\n@rem distributed under the License is distributed on an \"AS IS\" BASIS,\n@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n@rem See the License for the specific language governing permissions and\n@rem limitations under the License.\n@rem\n\n@if \"%DEBUG%\" == \"\" @echo off\n@rem ##########################################################################\n@rem\n@rem  Gradle startup script for Windows\n@rem\n@rem ##########################################################################\n\n@rem Set local scope for the variables with windows NT shell\nif \"%OS%\"==\"Windows_NT\" setlocal\n\nset DIRNAME=%~dp0\nif \"%DIRNAME%\" == \"\" set DIRNAME=.\nset APP_BASE_NAME=%~n0\nset APP_HOME=%DIRNAME%\n\n@rem Resolve any \".\" and \"..\" in APP_HOME to make it shorter.\nfor %%i in (\"%APP_HOME%\") do set APP_HOME=%%~fi\n\n@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.\nset DEFAULT_JVM_OPTS=\"-Xmx64m\" \"-Xms64m\"\n\n@rem Find java.exe\nif defined JAVA_HOME goto findJavaFromJavaHome\n\nset JAVA_EXE=java.exe\n%JAVA_EXE% -version >NUL 2>&1\nif \"%ERRORLEVEL%\" == \"0\" goto execute\n\necho.\necho ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.\necho.\necho Please set the JAVA_HOME variable in your environment to match the\necho location of your Java installation.\n\ngoto fail\n\n:findJavaFromJavaHome\nset JAVA_HOME=%JAVA_HOME:\"=%\nset JAVA_EXE=%JAVA_HOME%/bin/java.exe\n\nif exist \"%JAVA_EXE%\" goto execute\n\necho.\necho ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%\necho.\necho Please set the JAVA_HOME variable in your environment to match the\necho location of your Java installation.\n\ngoto fail\n\n:execute\n@rem Setup the command line\n\nset CLASSPATH=%APP_HOME%\\gradle\\wrapper\\gradle-wrapper.jar\n\n\n@rem Execute Gradle\n\"%JAVA_EXE%\" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% \"-Dorg.gradle.appname=%APP_BASE_NAME%\" -classpath \"%CLASSPATH%\" org.gradle.wrapper.GradleWrapperMain %*\n\n:end\n@rem End local scope for the variables with windows NT shell\nif \"%ERRORLEVEL%\"==\"0\" goto mainEnd\n\n:fail\nrem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of\nrem the _cmd.exe /c_ return code!\nif  not \"\" == \"%GRADLE_EXIT_CONSOLE%\" exit 1\nexit /b 1\n\n:mainEnd\nif \"%OS%\"==\"Windows_NT\" endlocal\n\n:omega\n"
  },
  {
    "path": "scripts/publish-module.gradle",
    "content": "apply plugin: 'maven-publish'\napply plugin: 'signing'\n\ntasks.register('androidSourcesJar', Jar) {\n    archiveClassifier.set('sources')\n    if (project.plugins.findPlugin(\"com.android.library\")) {\n        from android.sourceSets.main.java.srcDirs\n    } else {\n        from sourceSets.main.java.srcDirs\n    }\n}\n\nartifacts {\n    archives androidSourcesJar\n}\ngroup = PUBLISH_GROUP_ID\nversion = rootProject.ext[\"publish_version\"]\n\nafterEvaluate {\n    publishing {\n        publications {\n            release(MavenPublication) {\n                tasks.named(\"generateMetadataFileForReleasePublication\").configure { dependsOn(\"androidSourcesJar\") }\n\n                groupId PUBLISH_GROUP_ID\n                artifactId PUBLISH_ARTIFACT_ID\n                version rootProject.ext[\"publish_version\"]\n\n                if (project.plugins.findPlugin(\"com.android.library\")) {\n                    from components.release\n                } else {\n                    artifact(\"$buildDir/libs/${project.getName()}-${version}.jar\")\n                }\n\n                pom {\n                    name = PUBLISH_ARTIFACT_ID\n                    description = 'Bottom bar in Jetpack Compose with customizable styles & animations'\n                    url = 'https://github.com/canopas/AnimatedBottomBarCompose'\n                    licenses {\n                        license {\n                            name = 'License'\n                            url = 'https://github.com/canopas/AnimatedBottomBarCompose/blob/master/License'\n                        }\n                    }\n                    developers {\n                        developer {\n                            id = 'cp-megh-l'\n                            name = 'Megh Canopas'\n                            email = 'megh.l@canopas.com'\n                        }\n                        // Add all other devs here...\n                    }\n\n                    scm {\n                        connection = 'scm:git:github.com/canopas/AnimatedBottomBarCompose.git'\n                        developerConnection = 'scm:git:ssh://github.com/canopas/AnimatedBottomBarCompose.git'\n                        url = 'https://github.com/canopas/AnimatedBottomBarCompose'\n                    }\n                }\n            }\n        }\n    }\n}\nsigning {\n    useInMemoryPgpKeys(\n            rootProject.ext[\"signing.keyId\"],\n            rootProject.ext[\"signing.key\"],\n            rootProject.ext[\"signing.password\"],\n    )\n\n    sign publishing.publications\n}"
  },
  {
    "path": "scripts/publish-root.gradle",
    "content": "// Create variables with empty default values\next[\"ossrhUsername\"] = ''\next[\"ossrhPassword\"] = ''\next[\"sonatypeStagingProfileId\"] = ''\next[\"signing.keyId\"] = ''\next[\"signing.password\"] = ''\next[\"signing.key\"] = ''\next[\"snapshot\"] = ''\next[\"publish_version\"] = ''\n\nFile secretPropsFile = project.rootProject.file('local.properties')\n\nif (secretPropsFile.exists()) {\n\n    Properties p = new Properties()\n\n    new FileInputStream(secretPropsFile).withCloseable { is -> p.load(is) }\n\n    p.each { name, value -> ext[name] = value }\n\n} else {\n    ext[\"ossrhUsername\"] = System.getenv('OSSRH_USERNAME')\n    ext[\"ossrhPassword\"] = System.getenv('OSSRH_PASSWORD')\n    ext[\"sonatypeStagingProfileId\"] = System.getenv('SONATYPE_STAGING_PROFILE_ID')\n    ext[\"signing.keyId\"] = System.getenv('SIGNING_KEY_ID')\n    ext[\"signing.password\"] = System.getenv('SIGNING_PASSWORD')\n    ext[\"signing.key\"] = System.getenv('SIGNING_KEY')\n    ext[\"snapshot\"] = System.getenv('SNAPSHOT')\n    ext[\"publish_version\"] = System.getenv('PUBLISH_VERSION')\n}\n\nnexusPublishing {\n    repositories {\n        sonatype {\n            stagingProfileId = sonatypeStagingProfileId\n            username = ossrhUsername\n            password = ossrhPassword\n            nexusUrl.set(uri(\"https://s01.oss.sonatype.org/service/local/\"))\n            snapshotRepositoryUrl.set(uri(\"https://s01.oss.sonatype.org/content/repositories/snapshots/\"))\n        }\n    }\n}"
  },
  {
    "path": "settings.gradle.kts",
    "content": "pluginManagement {\n    repositories {\n        google()\n        mavenCentral()\n        gradlePluginPortal()\n    }\n}\ndependencyResolutionManagement {\n    repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)\n    repositories {\n        google()\n        mavenCentral()\n    }\n}\n\nrootProject.name = \"AnimatedBottomBarCompose\"\ninclude(\":app\")\ninclude(\":bottombar\")\n"
  }
]