rn-iconify 1.0.0 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +47 -235
- package/babel.js +14 -0
- package/lib/commonjs/IconRenderer.js +91 -4
- package/lib/commonjs/IconRenderer.js.map +1 -1
- package/lib/commonjs/accessibility/AccessibilityProvider.js +189 -0
- package/lib/commonjs/accessibility/AccessibilityProvider.js.map +1 -0
- package/lib/commonjs/accessibility/index.js +87 -0
- package/lib/commonjs/accessibility/index.js.map +1 -0
- package/lib/commonjs/accessibility/types.js +6 -0
- package/lib/commonjs/accessibility/types.js.map +1 -0
- package/lib/commonjs/accessibility/useAccessibleIcon.js +119 -0
- package/lib/commonjs/accessibility/useAccessibleIcon.js.map +1 -0
- package/lib/commonjs/accessibility/utils.js +231 -0
- package/lib/commonjs/accessibility/utils.js.map +1 -0
- package/lib/commonjs/alias/Icon.js +113 -0
- package/lib/commonjs/alias/Icon.js.map +1 -0
- package/lib/commonjs/alias/IconAliasContext.js +177 -0
- package/lib/commonjs/alias/IconAliasContext.js.map +1 -0
- package/lib/commonjs/alias/createIconAliases.js +222 -0
- package/lib/commonjs/alias/createIconAliases.js.map +1 -0
- package/lib/commonjs/alias/index.js +57 -0
- package/lib/commonjs/alias/index.js.map +1 -0
- package/lib/commonjs/alias/types.js +6 -0
- package/lib/commonjs/alias/types.js.map +1 -0
- package/lib/commonjs/animated/AnimatedIcon.js +116 -0
- package/lib/commonjs/animated/AnimatedIcon.js.map +1 -0
- package/lib/commonjs/animated/index.js +76 -0
- package/lib/commonjs/animated/index.js.map +1 -0
- package/lib/commonjs/animated/presets.js +220 -0
- package/lib/commonjs/animated/presets.js.map +1 -0
- package/lib/commonjs/animated/types.js +71 -0
- package/lib/commonjs/animated/types.js.map +1 -0
- package/lib/commonjs/animated/useIconAnimation.js +313 -0
- package/lib/commonjs/animated/useIconAnimation.js.map +1 -0
- package/lib/commonjs/babel/ast-utils.js +214 -0
- package/lib/commonjs/babel/ast-utils.js.map +1 -0
- package/lib/commonjs/babel/cache-writer.js +281 -0
- package/lib/commonjs/babel/cache-writer.js.map +1 -0
- package/lib/commonjs/babel/collector.js +219 -0
- package/lib/commonjs/babel/collector.js.map +1 -0
- package/lib/commonjs/babel/index.js +104 -0
- package/lib/commonjs/babel/index.js.map +1 -0
- package/lib/commonjs/babel/plugin.js +226 -0
- package/lib/commonjs/babel/plugin.js.map +1 -0
- package/lib/commonjs/babel/types.js +485 -0
- package/lib/commonjs/babel/types.js.map +1 -0
- package/lib/commonjs/bundle/index.js +213 -0
- package/lib/commonjs/bundle/index.js.map +1 -0
- package/lib/commonjs/cache/CacheManager.js +105 -6
- package/lib/commonjs/cache/CacheManager.js.map +1 -1
- package/lib/commonjs/cli/commands/analyze.js +171 -0
- package/lib/commonjs/cli/commands/analyze.js.map +1 -0
- package/lib/commonjs/cli/commands/bundle.js +214 -0
- package/lib/commonjs/cli/commands/bundle.js.map +1 -0
- package/lib/commonjs/cli/index.js +142 -0
- package/lib/commonjs/cli/index.js.map +1 -0
- package/lib/commonjs/cli/parser.js +260 -0
- package/lib/commonjs/cli/parser.js.map +1 -0
- package/lib/commonjs/cli/types.js +42 -0
- package/lib/commonjs/cli/types.js.map +1 -0
- package/lib/commonjs/config/ConfigManager.js +182 -0
- package/lib/commonjs/config/ConfigManager.js.map +1 -0
- package/lib/commonjs/config/index.js +44 -0
- package/lib/commonjs/config/index.js.map +1 -0
- package/lib/commonjs/config/types.js +55 -0
- package/lib/commonjs/config/types.js.map +1 -0
- package/lib/commonjs/createIconSet.js +49 -11
- package/lib/commonjs/createIconSet.js.map +1 -1
- package/lib/commonjs/explorer/IconExplorer.js +827 -0
- package/lib/commonjs/explorer/IconExplorer.js.map +1 -0
- package/lib/commonjs/explorer/iconSets.js +303 -0
- package/lib/commonjs/explorer/iconSets.js.map +1 -0
- package/lib/commonjs/explorer/index.js +93 -0
- package/lib/commonjs/explorer/index.js.map +1 -0
- package/lib/commonjs/explorer/types.js +6 -0
- package/lib/commonjs/explorer/types.js.map +1 -0
- package/lib/commonjs/explorer/useExplorer.js +359 -0
- package/lib/commonjs/explorer/useExplorer.js.map +1 -0
- package/lib/commonjs/index.js +618 -12
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/navigation/createDrawerIcon.js +129 -0
- package/lib/commonjs/navigation/createDrawerIcon.js.map +1 -0
- package/lib/commonjs/navigation/createHeaderIcon.js +185 -0
- package/lib/commonjs/navigation/createHeaderIcon.js.map +1 -0
- package/lib/commonjs/navigation/createTabBarIcon.js +178 -0
- package/lib/commonjs/navigation/createTabBarIcon.js.map +1 -0
- package/lib/commonjs/navigation/index.js +83 -0
- package/lib/commonjs/navigation/index.js.map +1 -0
- package/lib/commonjs/navigation/types.js +94 -0
- package/lib/commonjs/navigation/types.js.map +1 -0
- package/lib/commonjs/navigation/useNavigationIcon.js +128 -0
- package/lib/commonjs/navigation/useNavigationIcon.js.map +1 -0
- package/lib/commonjs/network/IconifyAPI.js +154 -14
- package/lib/commonjs/network/IconifyAPI.js.map +1 -1
- package/lib/commonjs/network/index.js +18 -0
- package/lib/commonjs/network/index.js.map +1 -1
- package/lib/commonjs/performance/PerformanceMonitor.js +327 -0
- package/lib/commonjs/performance/PerformanceMonitor.js.map +1 -0
- package/lib/commonjs/performance/index.js +43 -0
- package/lib/commonjs/performance/index.js.map +1 -0
- package/lib/commonjs/performance/types.js +2 -0
- package/lib/commonjs/performance/types.js.map +1 -0
- package/lib/commonjs/placeholder/PlaceholderFactory.js +111 -0
- package/lib/commonjs/placeholder/PlaceholderFactory.js.map +1 -0
- package/lib/commonjs/placeholder/Pulse.js +77 -0
- package/lib/commonjs/placeholder/Pulse.js.map +1 -0
- package/lib/commonjs/placeholder/Shimmer.js +95 -0
- package/lib/commonjs/placeholder/Shimmer.js.map +1 -0
- package/lib/commonjs/placeholder/Skeleton.js +52 -0
- package/lib/commonjs/placeholder/Skeleton.js.map +1 -0
- package/lib/commonjs/placeholder/index.js +41 -0
- package/lib/commonjs/placeholder/index.js.map +1 -0
- package/lib/commonjs/placeholder/types.js +40 -0
- package/lib/commonjs/placeholder/types.js.map +1 -0
- package/lib/commonjs/theme/IconThemeProvider.js +96 -0
- package/lib/commonjs/theme/IconThemeProvider.js.map +1 -0
- package/lib/commonjs/theme/context.js +53 -0
- package/lib/commonjs/theme/context.js.map +1 -0
- package/lib/commonjs/theme/index.js +52 -0
- package/lib/commonjs/theme/index.js.map +1 -0
- package/lib/commonjs/theme/types.js +39 -0
- package/lib/commonjs/theme/types.js.map +1 -0
- package/lib/commonjs/theme/useIconTheme.js +121 -0
- package/lib/commonjs/theme/useIconTheme.js.map +1 -0
- package/lib/module/IconRenderer.js +92 -5
- package/lib/module/IconRenderer.js.map +1 -1
- package/lib/module/accessibility/AccessibilityProvider.js +179 -0
- package/lib/module/accessibility/AccessibilityProvider.js.map +1 -0
- package/lib/module/accessibility/index.js +42 -0
- package/lib/module/accessibility/index.js.map +1 -0
- package/lib/module/accessibility/types.js +2 -0
- package/lib/module/accessibility/types.js.map +1 -0
- package/lib/module/accessibility/useAccessibleIcon.js +112 -0
- package/lib/module/accessibility/useAccessibleIcon.js.map +1 -0
- package/lib/module/accessibility/utils.js +221 -0
- package/lib/module/accessibility/utils.js.map +1 -0
- package/lib/module/alias/Icon.js +105 -0
- package/lib/module/alias/Icon.js.map +1 -0
- package/lib/module/alias/IconAliasContext.js +166 -0
- package/lib/module/alias/IconAliasContext.js.map +1 -0
- package/lib/module/alias/createIconAliases.js +213 -0
- package/lib/module/alias/createIconAliases.js.map +1 -0
- package/lib/module/alias/index.js +45 -0
- package/lib/module/alias/index.js.map +1 -0
- package/lib/module/alias/types.js +2 -0
- package/lib/module/alias/types.js.map +1 -0
- package/lib/module/animated/AnimatedIcon.js +109 -0
- package/lib/module/animated/AnimatedIcon.js.map +1 -0
- package/lib/module/animated/index.js +80 -0
- package/lib/module/animated/index.js.map +1 -0
- package/lib/module/animated/presets.js +209 -0
- package/lib/module/animated/presets.js.map +1 -0
- package/lib/module/animated/types.js +65 -0
- package/lib/module/animated/types.js.map +1 -0
- package/lib/module/animated/useIconAnimation.js +306 -0
- package/lib/module/animated/useIconAnimation.js.map +1 -0
- package/lib/module/babel/ast-utils.js +201 -0
- package/lib/module/babel/ast-utils.js.map +1 -0
- package/lib/module/babel/cache-writer.js +269 -0
- package/lib/module/babel/cache-writer.js.map +1 -0
- package/lib/module/babel/collector.js +214 -0
- package/lib/module/babel/collector.js.map +1 -0
- package/lib/module/babel/index.js +51 -0
- package/lib/module/babel/index.js.map +1 -0
- package/lib/module/babel/plugin.js +220 -0
- package/lib/module/babel/plugin.js.map +1 -0
- package/lib/module/babel/types.js +476 -0
- package/lib/module/babel/types.js.map +1 -0
- package/lib/module/bundle/index.js +205 -0
- package/lib/module/bundle/index.js.map +1 -0
- package/lib/module/cache/CacheManager.js +106 -6
- package/lib/module/cache/CacheManager.js.map +1 -1
- package/lib/module/cli/commands/analyze.js +166 -0
- package/lib/module/cli/commands/analyze.js.map +1 -0
- package/lib/module/cli/commands/bundle.js +208 -0
- package/lib/module/cli/commands/bundle.js.map +1 -0
- package/lib/module/cli/index.js +140 -0
- package/lib/module/cli/index.js.map +1 -0
- package/lib/module/cli/parser.js +251 -0
- package/lib/module/cli/parser.js.map +1 -0
- package/lib/module/cli/types.js +36 -0
- package/lib/module/cli/types.js.map +1 -0
- package/lib/module/components/index.js +27 -1
- package/lib/module/components/index.js.map +1 -1
- package/lib/module/config/ConfigManager.js +173 -0
- package/lib/module/config/ConfigManager.js.map +1 -0
- package/lib/module/config/index.js +28 -0
- package/lib/module/config/index.js.map +1 -0
- package/lib/module/config/types.js +49 -0
- package/lib/module/config/types.js.map +1 -0
- package/lib/module/createIconSet.js +49 -11
- package/lib/module/createIconSet.js.map +1 -1
- package/lib/module/explorer/IconExplorer.js +817 -0
- package/lib/module/explorer/IconExplorer.js.map +1 -0
- package/lib/module/explorer/iconSets.js +291 -0
- package/lib/module/explorer/iconSets.js.map +1 -0
- package/lib/module/explorer/index.js +42 -0
- package/lib/module/explorer/index.js.map +1 -0
- package/lib/module/explorer/types.js +2 -0
- package/lib/module/explorer/types.js.map +1 -0
- package/lib/module/explorer/useExplorer.js +353 -0
- package/lib/module/explorer/useExplorer.js.map +1 -0
- package/lib/module/index.js +26 -11
- package/lib/module/index.js.map +1 -1
- package/lib/module/navigation/createDrawerIcon.js +121 -0
- package/lib/module/navigation/createDrawerIcon.js.map +1 -0
- package/lib/module/navigation/createHeaderIcon.js +175 -0
- package/lib/module/navigation/createHeaderIcon.js.map +1 -0
- package/lib/module/navigation/createTabBarIcon.js +168 -0
- package/lib/module/navigation/createTabBarIcon.js.map +1 -0
- package/lib/module/navigation/index.js +59 -0
- package/lib/module/navigation/index.js.map +1 -0
- package/lib/module/navigation/types.js +88 -0
- package/lib/module/navigation/types.js.map +1 -0
- package/lib/module/navigation/useNavigationIcon.js +121 -0
- package/lib/module/navigation/useNavigationIcon.js.map +1 -0
- package/lib/module/network/IconifyAPI.js +152 -14
- package/lib/module/network/IconifyAPI.js.map +1 -1
- package/lib/module/network/index.js +1 -1
- package/lib/module/network/index.js.map +1 -1
- package/lib/module/performance/PerformanceMonitor.js +317 -0
- package/lib/module/performance/PerformanceMonitor.js.map +1 -0
- package/lib/module/performance/index.js +26 -0
- package/lib/module/performance/index.js.map +1 -0
- package/lib/module/performance/types.js +2 -0
- package/lib/module/performance/types.js.map +1 -0
- package/lib/module/placeholder/PlaceholderFactory.js +105 -0
- package/lib/module/placeholder/PlaceholderFactory.js.map +1 -0
- package/lib/module/placeholder/Pulse.js +70 -0
- package/lib/module/placeholder/Pulse.js.map +1 -0
- package/lib/module/placeholder/Shimmer.js +88 -0
- package/lib/module/placeholder/Shimmer.js.map +1 -0
- package/lib/module/placeholder/Skeleton.js +45 -0
- package/lib/module/placeholder/Skeleton.js.map +1 -0
- package/lib/module/placeholder/index.js +15 -0
- package/lib/module/placeholder/index.js.map +1 -0
- package/lib/module/placeholder/types.js +34 -0
- package/lib/module/placeholder/types.js.map +1 -0
- package/lib/module/theme/IconThemeProvider.js +89 -0
- package/lib/module/theme/IconThemeProvider.js.map +1 -0
- package/lib/module/theme/context.js +47 -0
- package/lib/module/theme/context.js.map +1 -0
- package/lib/module/theme/index.js +19 -0
- package/lib/module/theme/index.js.map +1 -0
- package/lib/module/theme/types.js +33 -0
- package/lib/module/theme/types.js.map +1 -0
- package/lib/module/theme/useIconTheme.js +114 -0
- package/lib/module/theme/useIconTheme.js.map +1 -0
- package/lib/typescript/IconRenderer.d.ts +1 -1
- package/lib/typescript/IconRenderer.d.ts.map +1 -1
- package/lib/typescript/accessibility/AccessibilityProvider.d.ts +57 -0
- package/lib/typescript/accessibility/AccessibilityProvider.d.ts.map +1 -0
- package/lib/typescript/accessibility/index.d.ts +37 -0
- package/lib/typescript/accessibility/index.d.ts.map +1 -0
- package/lib/typescript/accessibility/types.d.ts +130 -0
- package/lib/typescript/accessibility/types.d.ts.map +1 -0
- package/lib/typescript/accessibility/useAccessibleIcon.d.ts +111 -0
- package/lib/typescript/accessibility/useAccessibleIcon.d.ts.map +1 -0
- package/lib/typescript/accessibility/utils.d.ts +29 -0
- package/lib/typescript/accessibility/utils.d.ts.map +1 -0
- package/lib/typescript/alias/Icon.d.ts +38 -0
- package/lib/typescript/alias/Icon.d.ts.map +1 -0
- package/lib/typescript/alias/IconAliasContext.d.ts +52 -0
- package/lib/typescript/alias/IconAliasContext.d.ts.map +1 -0
- package/lib/typescript/alias/createIconAliases.d.ts +77 -0
- package/lib/typescript/alias/createIconAliases.d.ts.map +1 -0
- package/lib/typescript/alias/index.d.ts +36 -0
- package/lib/typescript/alias/index.d.ts.map +1 -0
- package/lib/typescript/alias/types.d.ts +115 -0
- package/lib/typescript/alias/types.d.ts.map +1 -0
- package/lib/typescript/animated/AnimatedIcon.d.ts +45 -0
- package/lib/typescript/animated/AnimatedIcon.d.ts.map +1 -0
- package/lib/typescript/animated/index.d.ts +70 -0
- package/lib/typescript/animated/index.d.ts.map +1 -0
- package/lib/typescript/animated/presets.d.ts +35 -0
- package/lib/typescript/animated/presets.d.ts.map +1 -0
- package/lib/typescript/animated/types.d.ts +196 -0
- package/lib/typescript/animated/types.d.ts.map +1 -0
- package/lib/typescript/animated/useIconAnimation.d.ts +64 -0
- package/lib/typescript/animated/useIconAnimation.d.ts.map +1 -0
- package/lib/typescript/babel/ast-utils.d.ts +52 -0
- package/lib/typescript/babel/ast-utils.d.ts.map +1 -0
- package/lib/typescript/babel/cache-writer.d.ts +56 -0
- package/lib/typescript/babel/cache-writer.d.ts.map +1 -0
- package/lib/typescript/babel/collector.d.ts +107 -0
- package/lib/typescript/babel/collector.d.ts.map +1 -0
- package/lib/typescript/babel/index.d.ts +47 -0
- package/lib/typescript/babel/index.d.ts.map +1 -0
- package/lib/typescript/babel/plugin.d.ts +17 -0
- package/lib/typescript/babel/plugin.d.ts.map +1 -0
- package/lib/typescript/babel/types.d.ts +129 -0
- package/lib/typescript/babel/types.d.ts.map +1 -0
- package/lib/typescript/bundle/index.d.ts +161 -0
- package/lib/typescript/bundle/index.d.ts.map +1 -0
- package/lib/typescript/cache/CacheManager.d.ts +52 -4
- package/lib/typescript/cache/CacheManager.d.ts.map +1 -1
- package/lib/typescript/cli/commands/analyze.d.ts +10 -0
- package/lib/typescript/cli/commands/analyze.d.ts.map +1 -0
- package/lib/typescript/cli/commands/bundle.d.ts +10 -0
- package/lib/typescript/cli/commands/bundle.d.ts.map +1 -0
- package/lib/typescript/cli/index.d.ts +7 -0
- package/lib/typescript/cli/index.d.ts.map +1 -0
- package/lib/typescript/cli/parser.d.ts +18 -0
- package/lib/typescript/cli/parser.d.ts.map +1 -0
- package/lib/typescript/cli/types.d.ts +157 -0
- package/lib/typescript/cli/types.d.ts.map +1 -0
- package/lib/typescript/components/Academicons.d.ts +1 -1
- package/lib/typescript/components/AkarIcons.d.ts +1 -1
- package/lib/typescript/components/AntDesign.d.ts +1 -1
- package/lib/typescript/components/Arcticons.d.ts +1 -1
- package/lib/typescript/components/Basil.d.ts +1 -1
- package/lib/typescript/components/Bi.d.ts +1 -1
- package/lib/typescript/components/BitcoinIcons.d.ts +1 -1
- package/lib/typescript/components/Bpmn.d.ts +1 -1
- package/lib/typescript/components/Brandico.d.ts +1 -1
- package/lib/typescript/components/Bx.d.ts +1 -1
- package/lib/typescript/components/Bxl.d.ts +1 -1
- package/lib/typescript/components/Bxs.d.ts +1 -1
- package/lib/typescript/components/Bytesize.d.ts +1 -1
- package/lib/typescript/components/Carbon.d.ts +1 -1
- package/lib/typescript/components/Catppuccin.d.ts +1 -1
- package/lib/typescript/components/Cbi.d.ts +1 -1
- package/lib/typescript/components/Charm.d.ts +1 -1
- package/lib/typescript/components/Ci.d.ts +1 -1
- package/lib/typescript/components/Cib.d.ts +1 -1
- package/lib/typescript/components/Cif.d.ts +1 -1
- package/lib/typescript/components/Cil.d.ts +1 -1
- package/lib/typescript/components/CircleFlags.d.ts +1 -1
- package/lib/typescript/components/Circum.d.ts +1 -1
- package/lib/typescript/components/Clarity.d.ts +1 -1
- package/lib/typescript/components/Codex.d.ts +1 -1
- package/lib/typescript/components/Codicon.d.ts +1 -1
- package/lib/typescript/components/Covid.d.ts +1 -1
- package/lib/typescript/components/Cryptocurrency.d.ts +1 -1
- package/lib/typescript/components/CryptocurrencyColor.d.ts +1 -1
- package/lib/typescript/components/Cuida.d.ts +1 -1
- package/lib/typescript/components/Dashicons.d.ts +1 -1
- package/lib/typescript/components/Devicon.d.ts +1 -1
- package/lib/typescript/components/DeviconPlain.d.ts +1 -1
- package/lib/typescript/components/DinkieIcons.d.ts +1 -1
- package/lib/typescript/components/DuoIcons.d.ts +1 -1
- package/lib/typescript/components/Ei.d.ts +1 -1
- package/lib/typescript/components/El.d.ts +1 -1
- package/lib/typescript/components/EmojioneMonotone.d.ts +1 -1
- package/lib/typescript/components/Entypo.d.ts +1 -1
- package/lib/typescript/components/EntypoSocial.d.ts +1 -1
- package/lib/typescript/components/EosIcons.d.ts +1 -1
- package/lib/typescript/components/Ep.d.ts +1 -1
- package/lib/typescript/components/Et.d.ts +1 -1
- package/lib/typescript/components/Eva.d.ts +1 -1
- package/lib/typescript/components/F7.d.ts +1 -1
- package/lib/typescript/components/Fa.d.ts +1 -1
- package/lib/typescript/components/Fa6Brands.d.ts +1 -1
- package/lib/typescript/components/Fa6Regular.d.ts +1 -1
- package/lib/typescript/components/Fa6Solid.d.ts +1 -1
- package/lib/typescript/components/Fa7Brands.d.ts +1 -1
- package/lib/typescript/components/Fa7Regular.d.ts +1 -1
- package/lib/typescript/components/Fa7Solid.d.ts +1 -1
- package/lib/typescript/components/FaBrands.d.ts +1 -1
- package/lib/typescript/components/FaRegular.d.ts +1 -1
- package/lib/typescript/components/FaSolid.d.ts +1 -1
- package/lib/typescript/components/Fad.d.ts +1 -1
- package/lib/typescript/components/Famicons.d.ts +1 -1
- package/lib/typescript/components/Fe.d.ts +1 -1
- package/lib/typescript/components/Feather.d.ts +1 -1
- package/lib/typescript/components/FileIcons.d.ts +1 -1
- package/lib/typescript/components/Flag.d.ts +1 -1
- package/lib/typescript/components/Flagpack.d.ts +1 -1
- package/lib/typescript/components/FlatUi.d.ts +1 -1
- package/lib/typescript/components/Flowbite.d.ts +1 -1
- package/lib/typescript/components/Fluent.d.ts +1 -1
- package/lib/typescript/components/FluentColor.d.ts +1 -1
- package/lib/typescript/components/FluentEmoji.d.ts +1 -1
- package/lib/typescript/components/FluentEmojiFlat.d.ts +1 -1
- package/lib/typescript/components/FluentEmojiHighContrast.d.ts +1 -1
- package/lib/typescript/components/FluentMdl2.d.ts +1 -1
- package/lib/typescript/components/Fontelico.d.ts +1 -1
- package/lib/typescript/components/Fontisto.d.ts +1 -1
- package/lib/typescript/components/Formkit.d.ts +1 -1
- package/lib/typescript/components/Foundation.d.ts +1 -1
- package/lib/typescript/components/Gala.d.ts +1 -1
- package/lib/typescript/components/GameIcons.d.ts +1 -1
- package/lib/typescript/components/Garden.d.ts +1 -1
- package/lib/typescript/components/Geo.d.ts +1 -1
- package/lib/typescript/components/Gg.d.ts +1 -1
- package/lib/typescript/components/Gis.d.ts +1 -1
- package/lib/typescript/components/GravityUi.d.ts +1 -1
- package/lib/typescript/components/Gridicons.d.ts +1 -1
- package/lib/typescript/components/GrommetIcons.d.ts +1 -1
- package/lib/typescript/components/Guidance.d.ts +1 -1
- package/lib/typescript/components/Healthicons.d.ts +1 -1
- package/lib/typescript/components/Heroicons.d.ts +1 -1
- package/lib/typescript/components/HeroiconsOutline.d.ts +1 -1
- package/lib/typescript/components/HeroiconsSolid.d.ts +1 -1
- package/lib/typescript/components/Hugeicons.d.ts +1 -1
- package/lib/typescript/components/Humbleicons.d.ts +1 -1
- package/lib/typescript/components/Ic.d.ts +1 -1
- package/lib/typescript/components/IcomoonFree.d.ts +1 -1
- package/lib/typescript/components/IconPark.d.ts +1 -1
- package/lib/typescript/components/IconParkOutline.d.ts +1 -1
- package/lib/typescript/components/IconParkSolid.d.ts +1 -1
- package/lib/typescript/components/IconParkTwotone.d.ts +1 -1
- package/lib/typescript/components/Iconamoon.d.ts +1 -1
- package/lib/typescript/components/Iconoir.d.ts +1 -1
- package/lib/typescript/components/Icons8.d.ts +1 -1
- package/lib/typescript/components/Il.d.ts +1 -1
- package/lib/typescript/components/Ion.d.ts +1 -1
- package/lib/typescript/components/Iwwa.d.ts +1 -1
- package/lib/typescript/components/Ix.d.ts +1 -1
- package/lib/typescript/components/Jam.d.ts +1 -1
- package/lib/typescript/components/La.d.ts +1 -1
- package/lib/typescript/components/LetsIcons.d.ts +1 -1
- package/lib/typescript/components/LineMd.d.ts +1 -1
- package/lib/typescript/components/Lineicons.d.ts +1 -1
- package/lib/typescript/components/Logos.d.ts +1 -1
- package/lib/typescript/components/Ls.d.ts +1 -1
- package/lib/typescript/components/Lsicon.d.ts +1 -1
- package/lib/typescript/components/Lucide.d.ts +1 -1
- package/lib/typescript/components/LucideLab.d.ts +1 -1
- package/lib/typescript/components/Mage.d.ts +1 -1
- package/lib/typescript/components/Majesticons.d.ts +1 -1
- package/lib/typescript/components/Maki.d.ts +1 -1
- package/lib/typescript/components/Map.d.ts +1 -1
- package/lib/typescript/components/Marketeq.d.ts +1 -1
- package/lib/typescript/components/MaterialIconTheme.d.ts +1 -1
- package/lib/typescript/components/MaterialSymbols.d.ts +1 -1
- package/lib/typescript/components/MaterialSymbolsLight.d.ts +1 -1
- package/lib/typescript/components/Mdi.d.ts +1 -1
- package/lib/typescript/components/MdiLight.d.ts +1 -1
- package/lib/typescript/components/MedicalIcon.d.ts +1 -1
- package/lib/typescript/components/Memory.d.ts +1 -1
- package/lib/typescript/components/Meteocons.d.ts +1 -1
- package/lib/typescript/components/MeteorIcons.d.ts +1 -1
- package/lib/typescript/components/Mi.d.ts +1 -1
- package/lib/typescript/components/Mingcute.d.ts +1 -1
- package/lib/typescript/components/MonoIcons.d.ts +1 -1
- package/lib/typescript/components/Mynaui.d.ts +1 -1
- package/lib/typescript/components/Nimbus.d.ts +1 -1
- package/lib/typescript/components/Nonicons.d.ts +1 -1
- package/lib/typescript/components/Nrk.d.ts +1 -1
- package/lib/typescript/components/Octicon.d.ts +1 -1
- package/lib/typescript/components/Oi.d.ts +1 -1
- package/lib/typescript/components/Ooui.d.ts +1 -1
- package/lib/typescript/components/Oui.d.ts +1 -1
- package/lib/typescript/components/Pajamas.d.ts +1 -1
- package/lib/typescript/components/Pepicons.d.ts +1 -1
- package/lib/typescript/components/PepiconsPencil.d.ts +1 -1
- package/lib/typescript/components/PepiconsPop.d.ts +1 -1
- package/lib/typescript/components/PepiconsPrint.d.ts +1 -1
- package/lib/typescript/components/Ph.d.ts +1 -1
- package/lib/typescript/components/Picon.d.ts +1 -1
- package/lib/typescript/components/Pixel.d.ts +1 -1
- package/lib/typescript/components/Pixelarticons.d.ts +1 -1
- package/lib/typescript/components/Prime.d.ts +1 -1
- package/lib/typescript/components/Proicons.d.ts +1 -1
- package/lib/typescript/components/Ps.d.ts +1 -1
- package/lib/typescript/components/QlementineIcons.d.ts +1 -1
- package/lib/typescript/components/Quill.d.ts +1 -1
- package/lib/typescript/components/RadixIcons.d.ts +1 -1
- package/lib/typescript/components/Raphael.d.ts +1 -1
- package/lib/typescript/components/Ri.d.ts +1 -1
- package/lib/typescript/components/RivetIcons.d.ts +1 -1
- package/lib/typescript/components/Roentgen.d.ts +1 -1
- package/lib/typescript/components/Si.d.ts +1 -1
- package/lib/typescript/components/SiGlyph.d.ts +1 -1
- package/lib/typescript/components/Sidekickicons.d.ts +1 -1
- package/lib/typescript/components/SimpleIcons.d.ts +1 -1
- package/lib/typescript/components/SimpleLineIcons.d.ts +1 -1
- package/lib/typescript/components/SkillIcons.d.ts +1 -1
- package/lib/typescript/components/Solar.d.ts +1 -1
- package/lib/typescript/components/Stash.d.ts +1 -1
- package/lib/typescript/components/Streamline.d.ts +1 -1
- package/lib/typescript/components/StreamlineBlock.d.ts +1 -1
- package/lib/typescript/components/StreamlineColor.d.ts +1 -1
- package/lib/typescript/components/StreamlineCyber.d.ts +1 -1
- package/lib/typescript/components/StreamlineCyberColor.d.ts +1 -1
- package/lib/typescript/components/StreamlineEmojis.d.ts +1 -1
- package/lib/typescript/components/StreamlineFlex.d.ts +1 -1
- package/lib/typescript/components/StreamlineFlexColor.d.ts +1 -1
- package/lib/typescript/components/StreamlineFreehand.d.ts +1 -1
- package/lib/typescript/components/StreamlineFreehandColor.d.ts +1 -1
- package/lib/typescript/components/StreamlineKameleonColor.d.ts +1 -1
- package/lib/typescript/components/StreamlineLogos.d.ts +1 -1
- package/lib/typescript/components/StreamlinePixel.d.ts +1 -1
- package/lib/typescript/components/StreamlinePlump.d.ts +1 -1
- package/lib/typescript/components/StreamlinePlumpColor.d.ts +1 -1
- package/lib/typescript/components/StreamlineSharp.d.ts +1 -1
- package/lib/typescript/components/StreamlineSharpColor.d.ts +1 -1
- package/lib/typescript/components/StreamlineStickiesColor.d.ts +1 -1
- package/lib/typescript/components/StreamlineUltimate.d.ts +1 -1
- package/lib/typescript/components/StreamlineUltimateColor.d.ts +1 -1
- package/lib/typescript/components/Subway.d.ts +1 -1
- package/lib/typescript/components/SvgSpinners.d.ts +1 -1
- package/lib/typescript/components/SystemUicons.d.ts +1 -1
- package/lib/typescript/components/Tabler.d.ts +1 -1
- package/lib/typescript/components/Tdesign.d.ts +1 -1
- package/lib/typescript/components/Teenyicons.d.ts +1 -1
- package/lib/typescript/components/Temaki.d.ts +1 -1
- package/lib/typescript/components/Token.d.ts +1 -1
- package/lib/typescript/components/TokenBranded.d.ts +1 -1
- package/lib/typescript/components/Topcoat.d.ts +1 -1
- package/lib/typescript/components/Typcn.d.ts +1 -1
- package/lib/typescript/components/Uil.d.ts +1 -1
- package/lib/typescript/components/Uim.d.ts +1 -1
- package/lib/typescript/components/Uis.d.ts +1 -1
- package/lib/typescript/components/Uit.d.ts +1 -1
- package/lib/typescript/components/Uiw.d.ts +1 -1
- package/lib/typescript/components/Unjs.d.ts +1 -1
- package/lib/typescript/components/Vaadin.d.ts +1 -1
- package/lib/typescript/components/Vs.d.ts +1 -1
- package/lib/typescript/components/VscodeIcons.d.ts +1 -1
- package/lib/typescript/components/Websymbol.d.ts +1 -1
- package/lib/typescript/components/Weui.d.ts +1 -1
- package/lib/typescript/components/Whh.d.ts +1 -1
- package/lib/typescript/components/Wi.d.ts +1 -1
- package/lib/typescript/components/Wpf.d.ts +1 -1
- package/lib/typescript/components/Zmdi.d.ts +1 -1
- package/lib/typescript/components/Zondicons.d.ts +1 -1
- package/lib/typescript/components/index.d.ts +38 -1
- package/lib/typescript/components/index.d.ts.map +1 -1
- package/lib/typescript/config/ConfigManager.d.ts +102 -0
- package/lib/typescript/config/ConfigManager.d.ts.map +1 -0
- package/lib/typescript/config/index.d.ts +22 -0
- package/lib/typescript/config/index.d.ts.map +1 -0
- package/lib/typescript/config/types.d.ts +112 -0
- package/lib/typescript/config/types.d.ts.map +1 -0
- package/lib/typescript/createIconSet.d.ts +1 -1
- package/lib/typescript/createIconSet.d.ts.map +1 -1
- package/lib/typescript/explorer/IconExplorer.d.ts +54 -0
- package/lib/typescript/explorer/IconExplorer.d.ts.map +1 -0
- package/lib/typescript/explorer/iconSets.d.ts +35 -0
- package/lib/typescript/explorer/iconSets.d.ts.map +1 -0
- package/lib/typescript/explorer/index.d.ts +33 -0
- package/lib/typescript/explorer/index.d.ts.map +1 -0
- package/lib/typescript/explorer/types.d.ts +329 -0
- package/lib/typescript/explorer/types.d.ts.map +1 -0
- package/lib/typescript/explorer/useExplorer.d.ts +18 -0
- package/lib/typescript/explorer/useExplorer.d.ts.map +1 -0
- package/lib/typescript/index.d.ts +25 -4
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/navigation/createDrawerIcon.d.ts +74 -0
- package/lib/typescript/navigation/createDrawerIcon.d.ts.map +1 -0
- package/lib/typescript/navigation/createHeaderIcon.d.ts +145 -0
- package/lib/typescript/navigation/createHeaderIcon.d.ts.map +1 -0
- package/lib/typescript/navigation/createTabBarIcon.d.ts +99 -0
- package/lib/typescript/navigation/createTabBarIcon.d.ts.map +1 -0
- package/lib/typescript/navigation/index.d.ts +51 -0
- package/lib/typescript/navigation/index.d.ts.map +1 -0
- package/lib/typescript/navigation/types.d.ts +149 -0
- package/lib/typescript/navigation/types.d.ts.map +1 -0
- package/lib/typescript/navigation/useNavigationIcon.d.ts +91 -0
- package/lib/typescript/navigation/useNavigationIcon.d.ts.map +1 -0
- package/lib/typescript/network/IconifyAPI.d.ts +32 -0
- package/lib/typescript/network/IconifyAPI.d.ts.map +1 -1
- package/lib/typescript/network/index.d.ts +2 -1
- package/lib/typescript/network/index.d.ts.map +1 -1
- package/lib/typescript/performance/PerformanceMonitor.d.ts +76 -0
- package/lib/typescript/performance/PerformanceMonitor.d.ts.map +1 -0
- package/lib/typescript/performance/index.d.ts +21 -0
- package/lib/typescript/performance/index.d.ts.map +1 -0
- package/lib/typescript/performance/types.d.ts +156 -0
- package/lib/typescript/performance/types.d.ts.map +1 -0
- package/lib/typescript/placeholder/PlaceholderFactory.d.ts +44 -0
- package/lib/typescript/placeholder/PlaceholderFactory.d.ts.map +1 -0
- package/lib/typescript/placeholder/Pulse.d.ts +18 -0
- package/lib/typescript/placeholder/Pulse.d.ts.map +1 -0
- package/lib/typescript/placeholder/Shimmer.d.ts +19 -0
- package/lib/typescript/placeholder/Shimmer.d.ts.map +1 -0
- package/lib/typescript/placeholder/Skeleton.d.ts +18 -0
- package/lib/typescript/placeholder/Skeleton.d.ts.map +1 -0
- package/lib/typescript/placeholder/index.d.ts +12 -0
- package/lib/typescript/placeholder/index.d.ts.map +1 -0
- package/lib/typescript/placeholder/types.d.ts +63 -0
- package/lib/typescript/placeholder/types.d.ts.map +1 -0
- package/lib/typescript/theme/IconThemeProvider.d.ts +64 -0
- package/lib/typescript/theme/IconThemeProvider.d.ts.map +1 -0
- package/lib/typescript/theme/context.d.ts +24 -0
- package/lib/typescript/theme/context.d.ts.map +1 -0
- package/lib/typescript/theme/index.d.ts +10 -0
- package/lib/typescript/theme/index.d.ts.map +1 -0
- package/lib/typescript/theme/types.d.ts +85 -0
- package/lib/typescript/theme/types.d.ts.map +1 -0
- package/lib/typescript/theme/useIconTheme.d.ts +78 -0
- package/lib/typescript/theme/useIconTheme.d.ts.map +1 -0
- package/lib/typescript/types/index.d.ts +58 -1
- package/lib/typescript/types/index.d.ts.map +1 -1
- package/package.json +41 -3
- package/src/IconRenderer.tsx +91 -4
- package/src/accessibility/AccessibilityProvider.tsx +220 -0
- package/src/accessibility/index.ts +63 -0
- package/src/accessibility/types.ts +152 -0
- package/src/accessibility/useAccessibleIcon.ts +220 -0
- package/src/accessibility/utils.ts +180 -0
- package/src/alias/Icon.tsx +113 -0
- package/src/alias/IconAliasContext.tsx +180 -0
- package/src/alias/createIconAliases.tsx +233 -0
- package/src/alias/index.ts +59 -0
- package/src/alias/types.ts +132 -0
- package/src/animated/AnimatedIcon.tsx +116 -0
- package/src/animated/index.ts +97 -0
- package/src/animated/presets.ts +211 -0
- package/src/animated/types.ts +239 -0
- package/src/animated/useIconAnimation.ts +383 -0
- package/src/babel/ast-utils.ts +219 -0
- package/src/babel/cache-writer.ts +323 -0
- package/src/babel/collector.ts +224 -0
- package/src/babel/index.ts +60 -0
- package/src/babel/plugin.ts +254 -0
- package/src/babel/types.ts +717 -0
- package/src/bundle/index.ts +313 -0
- package/src/cache/CacheManager.ts +123 -6
- package/src/cli/commands/analyze.ts +195 -0
- package/src/cli/commands/bundle.ts +231 -0
- package/src/cli/index.ts +153 -0
- package/src/cli/parser.ts +275 -0
- package/src/cli/types.ts +187 -0
- package/src/components/index.ts +52 -1
- package/src/config/ConfigManager.ts +196 -0
- package/src/config/index.ts +34 -0
- package/src/config/types.ts +149 -0
- package/src/createIconSet.tsx +48 -9
- package/src/explorer/IconExplorer.tsx +844 -0
- package/src/explorer/iconSets.ts +334 -0
- package/src/explorer/index.ts +64 -0
- package/src/explorer/types.ts +392 -0
- package/src/explorer/useExplorer.ts +390 -0
- package/src/index.ts +218 -9
- package/src/navigation/createDrawerIcon.tsx +113 -0
- package/src/navigation/createHeaderIcon.tsx +213 -0
- package/src/navigation/createTabBarIcon.tsx +180 -0
- package/src/navigation/index.ts +80 -0
- package/src/navigation/types.ts +155 -0
- package/src/navigation/useNavigationIcon.tsx +156 -0
- package/src/network/IconifyAPI.ts +182 -14
- package/src/network/index.ts +11 -1
- package/src/performance/PerformanceMonitor.ts +367 -0
- package/src/performance/index.ts +39 -0
- package/src/performance/types.ts +185 -0
- package/src/placeholder/PlaceholderFactory.tsx +133 -0
- package/src/placeholder/Pulse.tsx +86 -0
- package/src/placeholder/Shimmer.tsx +104 -0
- package/src/placeholder/Skeleton.tsx +52 -0
- package/src/placeholder/index.ts +21 -0
- package/src/placeholder/types.ts +78 -0
- package/src/theme/IconThemeProvider.tsx +94 -0
- package/src/theme/context.ts +51 -0
- package/src/theme/index.ts +19 -0
- package/src/theme/types.ts +108 -0
- package/src/theme/useIconTheme.ts +119 -0
- package/src/types/index.ts +78 -1
- package/lib/commonjs/components/Phosphor.js +0 -493
- package/lib/commonjs/components/Phosphor.js.map +0 -1
- package/lib/module/components/Phosphor.js +0 -488
- package/lib/module/components/Phosphor.js.map +0 -1
- package/lib/typescript/components/Phosphor.d.ts +0 -472
- package/lib/typescript/components/Phosphor.d.ts.map +0 -1
- package/src/components/Phosphor.tsx +0 -506
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* createIconAliases - Factory function for creating type-safe icon aliases
|
|
3
|
+
* Provides full TypeScript autocomplete for alias names
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import React from 'react';
|
|
7
|
+
import { IconRenderer } from '../IconRenderer';
|
|
8
|
+
import { useIconTheme } from '../theme';
|
|
9
|
+
import { DEFAULT_ICON_THEME } from '../theme/types';
|
|
10
|
+
import { IconAliasProvider as BaseProvider } from './IconAliasContext';
|
|
11
|
+
/**
|
|
12
|
+
* Validate that all alias values are valid icon names
|
|
13
|
+
*/
|
|
14
|
+
function validateAliases(aliases) {
|
|
15
|
+
Object.entries(aliases).forEach(([alias, iconName]) => {
|
|
16
|
+
if (typeof iconName !== 'string') {
|
|
17
|
+
throw new Error(`[rn-iconify] Invalid alias value for "${alias}": expected string, got ${typeof iconName}`);
|
|
18
|
+
}
|
|
19
|
+
if (!iconName.includes(':')) {
|
|
20
|
+
throw new Error(`[rn-iconify] Invalid icon name for alias "${alias}": "${iconName}". ` + `Icon names must be in "prefix:name" format (e.g., "mdi:home").`);
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Create a type-safe icon alias system
|
|
27
|
+
*
|
|
28
|
+
* This function creates:
|
|
29
|
+
* - A typed Icon component with autocomplete for alias names
|
|
30
|
+
* - A Provider component to wrap your app
|
|
31
|
+
* - A resolve function to convert aliases to full icon names
|
|
32
|
+
*
|
|
33
|
+
* @example Basic usage
|
|
34
|
+
* ```tsx
|
|
35
|
+
* // icons.ts
|
|
36
|
+
* import { createIconAliases } from 'rn-iconify';
|
|
37
|
+
*
|
|
38
|
+
* export const { Icon, Provider: IconProvider, aliases } = createIconAliases({
|
|
39
|
+
* aliases: {
|
|
40
|
+
* back: 'mdi:arrow-left',
|
|
41
|
+
* forward: 'mdi:arrow-right',
|
|
42
|
+
* menu: 'heroicons:bars-3',
|
|
43
|
+
* close: 'mdi:close',
|
|
44
|
+
* home: 'mdi:home',
|
|
45
|
+
* settings: 'lucide:settings',
|
|
46
|
+
* } as const,
|
|
47
|
+
* });
|
|
48
|
+
*
|
|
49
|
+
* // App.tsx
|
|
50
|
+
* import { Icon, IconProvider } from './icons';
|
|
51
|
+
*
|
|
52
|
+
* function App() {
|
|
53
|
+
* return (
|
|
54
|
+
* <IconProvider>
|
|
55
|
+
* <Icon name="back" size={24} /> {// TypeScript autocomplete! }
|
|
56
|
+
* <Icon name="menu" color="blue" />
|
|
57
|
+
* </IconProvider>
|
|
58
|
+
* );
|
|
59
|
+
* }
|
|
60
|
+
* ```
|
|
61
|
+
*
|
|
62
|
+
* @example With navigation
|
|
63
|
+
* ```tsx
|
|
64
|
+
* import { Icon } from './icons';
|
|
65
|
+
*
|
|
66
|
+
* <Tab.Screen
|
|
67
|
+
* options={{
|
|
68
|
+
* tabBarIcon: ({ color, size }) => (
|
|
69
|
+
* <Icon name="home" color={color} size={size} />
|
|
70
|
+
* ),
|
|
71
|
+
* }}
|
|
72
|
+
* />
|
|
73
|
+
* ```
|
|
74
|
+
*/
|
|
75
|
+
export function createIconAliases(config) {
|
|
76
|
+
const {
|
|
77
|
+
aliases,
|
|
78
|
+
validate = true
|
|
79
|
+
} = config;
|
|
80
|
+
|
|
81
|
+
// Validate in development
|
|
82
|
+
if (__DEV__ && validate) {
|
|
83
|
+
validateAliases(aliases);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// Create resolve function
|
|
87
|
+
const resolve = name => {
|
|
88
|
+
// If it's already a full icon name, return as-is
|
|
89
|
+
if (name.includes(':')) {
|
|
90
|
+
return name;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
// Look up in aliases
|
|
94
|
+
const resolved = aliases[name];
|
|
95
|
+
if (resolved) {
|
|
96
|
+
return resolved;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
// Not found - warn in dev
|
|
100
|
+
if (__DEV__) {
|
|
101
|
+
console.warn(`[rn-iconify] Unknown alias "${name}". Available aliases: ${Object.keys(aliases).join(', ')}`);
|
|
102
|
+
}
|
|
103
|
+
return name;
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* Type-safe Icon component with alias support
|
|
108
|
+
*/
|
|
109
|
+
function TypedIcon({
|
|
110
|
+
name,
|
|
111
|
+
size,
|
|
112
|
+
color,
|
|
113
|
+
width,
|
|
114
|
+
height,
|
|
115
|
+
style,
|
|
116
|
+
rotate,
|
|
117
|
+
flip,
|
|
118
|
+
fallback,
|
|
119
|
+
fallbackDelay,
|
|
120
|
+
placeholder,
|
|
121
|
+
placeholderColor,
|
|
122
|
+
placeholderDuration,
|
|
123
|
+
onLoad,
|
|
124
|
+
onError,
|
|
125
|
+
accessibilityLabel,
|
|
126
|
+
testID
|
|
127
|
+
}) {
|
|
128
|
+
// Get theme defaults
|
|
129
|
+
const {
|
|
130
|
+
theme
|
|
131
|
+
} = useIconTheme();
|
|
132
|
+
|
|
133
|
+
// Resolve the icon name
|
|
134
|
+
const resolvedName = resolve(name);
|
|
135
|
+
|
|
136
|
+
// Merge props with theme defaults
|
|
137
|
+
const mergedSize = size ?? theme.size ?? DEFAULT_ICON_THEME.size;
|
|
138
|
+
const mergedColor = color ?? theme.color ?? DEFAULT_ICON_THEME.color;
|
|
139
|
+
const mergedRotate = rotate ?? theme.rotate ?? DEFAULT_ICON_THEME.rotate;
|
|
140
|
+
const mergedFlip = flip ?? theme.flip;
|
|
141
|
+
const mergedFallbackDelay = fallbackDelay ?? theme.fallbackDelay ?? DEFAULT_ICON_THEME.fallbackDelay;
|
|
142
|
+
const mergedPlaceholder = placeholder ?? theme.placeholder;
|
|
143
|
+
const mergedPlaceholderColor = placeholderColor ?? theme.placeholderColor ?? DEFAULT_ICON_THEME.placeholderColor;
|
|
144
|
+
const mergedPlaceholderDuration = placeholderDuration ?? theme.placeholderDuration ?? DEFAULT_ICON_THEME.placeholderDuration;
|
|
145
|
+
return /*#__PURE__*/React.createElement(IconRenderer, {
|
|
146
|
+
iconName: resolvedName,
|
|
147
|
+
size: mergedSize,
|
|
148
|
+
color: mergedColor,
|
|
149
|
+
width: width,
|
|
150
|
+
height: height,
|
|
151
|
+
style: style,
|
|
152
|
+
rotate: mergedRotate,
|
|
153
|
+
flip: mergedFlip,
|
|
154
|
+
fallback: fallback,
|
|
155
|
+
fallbackDelay: mergedFallbackDelay,
|
|
156
|
+
placeholder: mergedPlaceholder,
|
|
157
|
+
placeholderColor: mergedPlaceholderColor,
|
|
158
|
+
placeholderDuration: mergedPlaceholderDuration,
|
|
159
|
+
onLoad: onLoad,
|
|
160
|
+
onError: onError,
|
|
161
|
+
accessibilityLabel: accessibilityLabel ?? name,
|
|
162
|
+
testID: testID
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
TypedIcon.displayName = 'TypedIcon';
|
|
166
|
+
|
|
167
|
+
/**
|
|
168
|
+
* Provider component (pre-configured with aliases)
|
|
169
|
+
*/
|
|
170
|
+
function Provider({
|
|
171
|
+
children
|
|
172
|
+
}) {
|
|
173
|
+
return /*#__PURE__*/React.createElement(BaseProvider, {
|
|
174
|
+
aliases: aliases
|
|
175
|
+
}, children);
|
|
176
|
+
}
|
|
177
|
+
Provider.displayName = 'IconAliasProvider';
|
|
178
|
+
return {
|
|
179
|
+
aliases: aliases,
|
|
180
|
+
Icon: TypedIcon,
|
|
181
|
+
Provider,
|
|
182
|
+
resolve,
|
|
183
|
+
// Type helper - this is just for type inference, not a runtime value
|
|
184
|
+
AliasName: ''
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
/**
|
|
189
|
+
* Quick helper to create aliases without full type safety
|
|
190
|
+
* Useful for simple cases or when aliases are dynamic
|
|
191
|
+
*
|
|
192
|
+
* @example
|
|
193
|
+
* ```tsx
|
|
194
|
+
* import { defineAliases, Icon, IconAliasProvider } from 'rn-iconify';
|
|
195
|
+
*
|
|
196
|
+
* const aliases = defineAliases({
|
|
197
|
+
* back: 'mdi:arrow-left',
|
|
198
|
+
* menu: 'heroicons:bars-3',
|
|
199
|
+
* });
|
|
200
|
+
*
|
|
201
|
+
* <IconAliasProvider aliases={aliases}>
|
|
202
|
+
* <Icon name="back" />
|
|
203
|
+
* </IconAliasProvider>
|
|
204
|
+
* ```
|
|
205
|
+
*/
|
|
206
|
+
export function defineAliases(aliases) {
|
|
207
|
+
if (__DEV__) {
|
|
208
|
+
validateAliases(aliases);
|
|
209
|
+
}
|
|
210
|
+
return aliases;
|
|
211
|
+
}
|
|
212
|
+
export default createIconAliases;
|
|
213
|
+
//# sourceMappingURL=createIconAliases.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","IconRenderer","useIconTheme","DEFAULT_ICON_THEME","IconAliasProvider","BaseProvider","validateAliases","aliases","Object","entries","forEach","alias","iconName","Error","includes","createIconAliases","config","validate","__DEV__","resolve","name","resolved","console","warn","keys","join","TypedIcon","size","color","width","height","style","rotate","flip","fallback","fallbackDelay","placeholder","placeholderColor","placeholderDuration","onLoad","onError","accessibilityLabel","testID","theme","resolvedName","mergedSize","mergedColor","mergedRotate","mergedFlip","mergedFallbackDelay","mergedPlaceholder","mergedPlaceholderColor","mergedPlaceholderDuration","createElement","displayName","Provider","children","Icon","AliasName","defineAliases"],"sourceRoot":"../../../src","sources":["alias/createIconAliases.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Icon Alias System
|
|
3
|
+
* Create custom icon name mappings for consistent usage across your app
|
|
4
|
+
*
|
|
5
|
+
* @example Basic usage
|
|
6
|
+
* ```tsx
|
|
7
|
+
* import { createIconAliases } from 'rn-iconify';
|
|
8
|
+
*
|
|
9
|
+
* const { Icon, Provider } = createIconAliases({
|
|
10
|
+
* aliases: {
|
|
11
|
+
* back: 'mdi:arrow-left',
|
|
12
|
+
* menu: 'heroicons:bars-3',
|
|
13
|
+
* } as const,
|
|
14
|
+
* });
|
|
15
|
+
*
|
|
16
|
+
* <Provider>
|
|
17
|
+
* <Icon name="back" />
|
|
18
|
+
* </Provider>
|
|
19
|
+
* ```
|
|
20
|
+
*
|
|
21
|
+
* @example With generic Icon component
|
|
22
|
+
* ```tsx
|
|
23
|
+
* import { Icon, IconAliasProvider } from 'rn-iconify';
|
|
24
|
+
*
|
|
25
|
+
* <IconAliasProvider aliases={{ back: 'mdi:arrow-left' }}>
|
|
26
|
+
* <Icon name="back" />
|
|
27
|
+
* <Icon name="mdi:home" /> // Full names still work
|
|
28
|
+
* </IconAliasProvider>
|
|
29
|
+
* ```
|
|
30
|
+
*/
|
|
31
|
+
|
|
32
|
+
// Types
|
|
33
|
+
|
|
34
|
+
// Context and Provider
|
|
35
|
+
export { IconAliasContext, IconAliasProvider, useIconAliasContext, useResolveIcon } from './IconAliasContext';
|
|
36
|
+
|
|
37
|
+
// Generic Icon component
|
|
38
|
+
export { Icon } from './Icon';
|
|
39
|
+
|
|
40
|
+
// Factory functions
|
|
41
|
+
export { createIconAliases, defineAliases } from './createIconAliases';
|
|
42
|
+
|
|
43
|
+
// Default export
|
|
44
|
+
export { createIconAliases as default } from './createIconAliases';
|
|
45
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["IconAliasContext","IconAliasProvider","useIconAliasContext","useResolveIcon","Icon","createIconAliases","defineAliases","default"],"sourceRoot":"../../../src","sources":["alias/index.ts"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAYA;AACA,SACEA,gBAAgB,EAChBC,iBAAiB,EACjBC,mBAAmB,EACnBC,cAAc,QACT,oBAAoB;;AAE3B;AACA,SAASC,IAAI,QAAQ,QAAQ;;AAE7B;AACA,SAASC,iBAAiB,EAAEC,aAAa,QAAQ,qBAAqB;;AAEtE;AACA,SAASD,iBAAiB,IAAIE,OAAO,QAAQ,qBAAqB","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["alias/types.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AnimatedIcon - Wrapper component for animated icons
|
|
3
|
+
* Provides animation capabilities to any icon component
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import React, { forwardRef, useImperativeHandle } from 'react';
|
|
7
|
+
import { Animated, StyleSheet } from 'react-native';
|
|
8
|
+
import { useIconAnimation } from './useIconAnimation';
|
|
9
|
+
/**
|
|
10
|
+
* AnimatedIcon wrapper component
|
|
11
|
+
* Wraps any icon component to add animation capabilities
|
|
12
|
+
*
|
|
13
|
+
* @example Basic usage
|
|
14
|
+
* ```tsx
|
|
15
|
+
* import { AnimatedIcon } from 'rn-iconify/animated';
|
|
16
|
+
* import { Mdi } from 'rn-iconify';
|
|
17
|
+
*
|
|
18
|
+
* <AnimatedIcon animate="spin">
|
|
19
|
+
* <Mdi name="loading" size={24} />
|
|
20
|
+
* </AnimatedIcon>
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @example With custom configuration
|
|
24
|
+
* ```tsx
|
|
25
|
+
* <AnimatedIcon
|
|
26
|
+
* animate={{ type: 'rotate', duration: 2000, easing: 'linear' }}
|
|
27
|
+
* autoPlay={true}
|
|
28
|
+
* >
|
|
29
|
+
* <Mdi name="sync" size={24} />
|
|
30
|
+
* </AnimatedIcon>
|
|
31
|
+
* ```
|
|
32
|
+
*
|
|
33
|
+
* @example With ref for animation control
|
|
34
|
+
* ```tsx
|
|
35
|
+
* const animationRef = useRef<AnimationControls>(null);
|
|
36
|
+
*
|
|
37
|
+
* <AnimatedIcon ref={animationRef} animate="bounce" autoPlay={false}>
|
|
38
|
+
* <Mdi name="heart" size={24} />
|
|
39
|
+
* </AnimatedIcon>
|
|
40
|
+
*
|
|
41
|
+
* // Later
|
|
42
|
+
* animationRef.current?.start();
|
|
43
|
+
* ```
|
|
44
|
+
*/
|
|
45
|
+
export const AnimatedIcon = /*#__PURE__*/forwardRef(function AnimatedIcon({
|
|
46
|
+
children,
|
|
47
|
+
animate,
|
|
48
|
+
animationDuration,
|
|
49
|
+
animationLoop,
|
|
50
|
+
animationEasing,
|
|
51
|
+
animationDelay,
|
|
52
|
+
autoPlay = true,
|
|
53
|
+
onAnimationComplete,
|
|
54
|
+
width,
|
|
55
|
+
height,
|
|
56
|
+
testID
|
|
57
|
+
}, ref) {
|
|
58
|
+
const {
|
|
59
|
+
animatedStyle,
|
|
60
|
+
hasAnimation,
|
|
61
|
+
start,
|
|
62
|
+
stop,
|
|
63
|
+
pause,
|
|
64
|
+
resume,
|
|
65
|
+
reset,
|
|
66
|
+
state,
|
|
67
|
+
isAnimating
|
|
68
|
+
} = useIconAnimation({
|
|
69
|
+
animation: animate,
|
|
70
|
+
duration: animationDuration,
|
|
71
|
+
loop: animationLoop,
|
|
72
|
+
easing: animationEasing,
|
|
73
|
+
delay: animationDelay,
|
|
74
|
+
autoPlay,
|
|
75
|
+
onComplete: onAnimationComplete
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
// Expose animation controls via ref
|
|
79
|
+
useImperativeHandle(ref, () => ({
|
|
80
|
+
start,
|
|
81
|
+
stop,
|
|
82
|
+
pause,
|
|
83
|
+
resume,
|
|
84
|
+
reset,
|
|
85
|
+
state,
|
|
86
|
+
isAnimating
|
|
87
|
+
}), [start, stop, pause, resume, reset, state, isAnimating]);
|
|
88
|
+
|
|
89
|
+
// If no animation, render children directly
|
|
90
|
+
if (!hasAnimation) {
|
|
91
|
+
return /*#__PURE__*/React.createElement(React.Fragment, null, children);
|
|
92
|
+
}
|
|
93
|
+
return /*#__PURE__*/React.createElement(Animated.View, {
|
|
94
|
+
style: [styles.container, width !== undefined && {
|
|
95
|
+
width
|
|
96
|
+
}, height !== undefined && {
|
|
97
|
+
height
|
|
98
|
+
}, animatedStyle],
|
|
99
|
+
testID: testID
|
|
100
|
+
}, children);
|
|
101
|
+
});
|
|
102
|
+
const styles = StyleSheet.create({
|
|
103
|
+
container: {
|
|
104
|
+
alignItems: 'center',
|
|
105
|
+
justifyContent: 'center'
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
export default AnimatedIcon;
|
|
109
|
+
//# sourceMappingURL=AnimatedIcon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","forwardRef","useImperativeHandle","Animated","StyleSheet","useIconAnimation","AnimatedIcon","children","animate","animationDuration","animationLoop","animationEasing","animationDelay","autoPlay","onAnimationComplete","width","height","testID","ref","animatedStyle","hasAnimation","start","stop","pause","resume","reset","state","isAnimating","animation","duration","loop","easing","delay","onComplete","createElement","Fragment","View","style","styles","container","undefined","create","alignItems","justifyContent"],"sourceRoot":"../../../src","sources":["animated/AnimatedIcon.tsx"],"mappings":"AAAA;AACA;AACA;AACA;;AAEA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,mBAAmB,QAAQ,OAAO;AAC9D,SAASC,QAAQ,EAAEC,UAAU,QAAQ,cAAc;AACnD,SAASC,gBAAgB,QAAQ,oBAAoB;AAGrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,YAAY,gBAAGL,UAAU,CAAuC,SAASK,YAAYA,CAChG;EACEC,QAAQ;EACRC,OAAO;EACPC,iBAAiB;EACjBC,aAAa;EACbC,eAAe;EACfC,cAAc;EACdC,QAAQ,GAAG,IAAI;EACfC,mBAAmB;EACnBC,KAAK;EACLC,MAAM;EACNC;AACF,CAAC,EACDC,GAAG,EACH;EACA,MAAM;IAAEC,aAAa;IAAEC,YAAY;IAAEC,KAAK;IAAEC,IAAI;IAAEC,KAAK;IAAEC,MAAM;IAAEC,KAAK;IAAEC,KAAK;IAAEC;EAAY,CAAC,GAC1FtB,gBAAgB,CAAC;IACfuB,SAAS,EAAEpB,OAAO;IAClBqB,QAAQ,EAAEpB,iBAAiB;IAC3BqB,IAAI,EAAEpB,aAAa;IACnBqB,MAAM,EAAEpB,eAAe;IACvBqB,KAAK,EAAEpB,cAAc;IACrBC,QAAQ;IACRoB,UAAU,EAAEnB;EACd,CAAC,CAAC;;EAEJ;EACAZ,mBAAmB,CACjBgB,GAAG,EACH,OAAO;IACLG,KAAK;IACLC,IAAI;IACJC,KAAK;IACLC,MAAM;IACNC,KAAK;IACLC,KAAK;IACLC;EACF,CAAC,CAAC,EACF,CAACN,KAAK,EAAEC,IAAI,EAAEC,KAAK,EAAEC,MAAM,EAAEC,KAAK,EAAEC,KAAK,EAAEC,WAAW,CACxD,CAAC;;EAED;EACA,IAAI,CAACP,YAAY,EAAE;IACjB,oBAAOpB,KAAA,CAAAkC,aAAA,CAAAlC,KAAA,CAAAmC,QAAA,QAAG5B,QAAW,CAAC;EACxB;EAEA,oBACEP,KAAA,CAAAkC,aAAA,CAAC/B,QAAQ,CAACiC,IAAI;IACZC,KAAK,EAAE,CACLC,MAAM,CAACC,SAAS,EAChBxB,KAAK,KAAKyB,SAAS,IAAI;MAAEzB;IAAM,CAAC,EAChCC,MAAM,KAAKwB,SAAS,IAAI;MAAExB;IAAO,CAAC,EAClCG,aAAa,CACb;IACFF,MAAM,EAAEA;EAAO,GAEdV,QACY,CAAC;AAEpB,CAAC,CAAC;AAEF,MAAM+B,MAAM,GAAGlC,UAAU,CAACqC,MAAM,CAAC;EAC/BF,SAAS,EAAE;IACTG,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE;EAClB;AACF,CAAC,CAAC;AAEF,eAAerC,YAAY","ignoreList":[]}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Animated Icons Module
|
|
3
|
+
* Provides animation capabilities for rn-iconify icons
|
|
4
|
+
*
|
|
5
|
+
* @example Basic usage with preset
|
|
6
|
+
* ```tsx
|
|
7
|
+
* import { Mdi } from 'rn-iconify';
|
|
8
|
+
*
|
|
9
|
+
* // Direct usage with animate prop
|
|
10
|
+
* <Mdi name="loading" animate="spin" />
|
|
11
|
+
* <Mdi name="heart" animate="pulse" />
|
|
12
|
+
* <Mdi name="bell" animate="shake" />
|
|
13
|
+
* ```
|
|
14
|
+
*
|
|
15
|
+
* @example Using AnimatedIcon wrapper
|
|
16
|
+
* ```tsx
|
|
17
|
+
* import { AnimatedIcon } from 'rn-iconify/animated';
|
|
18
|
+
* import { Mdi } from 'rn-iconify';
|
|
19
|
+
*
|
|
20
|
+
* <AnimatedIcon animate="bounce">
|
|
21
|
+
* <Mdi name="star" size={24} />
|
|
22
|
+
* </AnimatedIcon>
|
|
23
|
+
* ```
|
|
24
|
+
*
|
|
25
|
+
* @example Custom animation configuration
|
|
26
|
+
* ```tsx
|
|
27
|
+
* <Mdi
|
|
28
|
+
* name="sync"
|
|
29
|
+
* animate={{
|
|
30
|
+
* type: 'rotate',
|
|
31
|
+
* duration: 2000,
|
|
32
|
+
* easing: 'linear',
|
|
33
|
+
* loop: true,
|
|
34
|
+
* }}
|
|
35
|
+
* />
|
|
36
|
+
* ```
|
|
37
|
+
*
|
|
38
|
+
* @example Animation control with ref
|
|
39
|
+
* ```tsx
|
|
40
|
+
* import { useRef } from 'react';
|
|
41
|
+
* import { AnimatedIcon, AnimationControls } from 'rn-iconify/animated';
|
|
42
|
+
*
|
|
43
|
+
* function MyComponent() {
|
|
44
|
+
* const animRef = useRef<AnimationControls>(null);
|
|
45
|
+
*
|
|
46
|
+
* const handlePress = () => {
|
|
47
|
+
* if (animRef.current?.isAnimating) {
|
|
48
|
+
* animRef.current.stop();
|
|
49
|
+
* } else {
|
|
50
|
+
* animRef.current?.start();
|
|
51
|
+
* }
|
|
52
|
+
* };
|
|
53
|
+
*
|
|
54
|
+
* return (
|
|
55
|
+
* <TouchableOpacity onPress={handlePress}>
|
|
56
|
+
* <AnimatedIcon ref={animRef} animate="spin" autoPlay={false}>
|
|
57
|
+
* <Mdi name="refresh" size={24} />
|
|
58
|
+
* </AnimatedIcon>
|
|
59
|
+
* </TouchableOpacity>
|
|
60
|
+
* );
|
|
61
|
+
* }
|
|
62
|
+
* ```
|
|
63
|
+
*/
|
|
64
|
+
|
|
65
|
+
// Types
|
|
66
|
+
|
|
67
|
+
export { DEFAULT_ANIMATION_DURATIONS, DEFAULT_ANIMATION_LOOPS } from './types';
|
|
68
|
+
|
|
69
|
+
// Presets
|
|
70
|
+
export { ANIMATION_PRESETS, getEasingFunction, resolveAnimation, isAnimationPreset, getDefaultDuration, getDefaultLoop } from './presets';
|
|
71
|
+
|
|
72
|
+
// Hook
|
|
73
|
+
export { useIconAnimation } from './useIconAnimation';
|
|
74
|
+
|
|
75
|
+
// Component
|
|
76
|
+
export { AnimatedIcon } from './AnimatedIcon';
|
|
77
|
+
|
|
78
|
+
// Default export
|
|
79
|
+
export { AnimatedIcon as default } from './AnimatedIcon';
|
|
80
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["DEFAULT_ANIMATION_DURATIONS","DEFAULT_ANIMATION_LOOPS","ANIMATION_PRESETS","getEasingFunction","resolveAnimation","isAnimationPreset","getDefaultDuration","getDefaultLoop","useIconAnimation","AnimatedIcon","default"],"sourceRoot":"../../../src","sources":["animated/index.ts"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAaA,SAASA,2BAA2B,EAAEC,uBAAuB,QAAQ,SAAS;;AAE9E;AACA,SACEC,iBAAiB,EACjBC,iBAAiB,EACjBC,gBAAgB,EAChBC,iBAAiB,EACjBC,kBAAkB,EAClBC,cAAc,QACT,WAAW;;AAElB;AACA,SAASC,gBAAgB,QAAQ,oBAAoB;;AAErD;AACA,SAASC,YAAY,QAAQ,gBAAgB;;AAE7C;AACA,SAASA,YAAY,IAAIC,OAAO,QAAQ,gBAAgB","ignoreList":[]}
|
|
@@ -0,0 +1,209 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Animation presets for rn-iconify
|
|
3
|
+
* Pre-configured animations for common use cases
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { Easing } from 'react-native';
|
|
7
|
+
/**
|
|
8
|
+
* Preset animation configurations
|
|
9
|
+
*/
|
|
10
|
+
export const ANIMATION_PRESETS = {
|
|
11
|
+
/**
|
|
12
|
+
* Continuous rotation (loading spinner)
|
|
13
|
+
*/
|
|
14
|
+
spin: {
|
|
15
|
+
type: 'rotate',
|
|
16
|
+
duration: 1000,
|
|
17
|
+
loop: true,
|
|
18
|
+
iterations: -1,
|
|
19
|
+
easing: 'linear',
|
|
20
|
+
direction: 'normal',
|
|
21
|
+
delay: 0,
|
|
22
|
+
from: 0,
|
|
23
|
+
to: 360
|
|
24
|
+
},
|
|
25
|
+
/**
|
|
26
|
+
* Pulsing opacity (heartbeat effect)
|
|
27
|
+
*/
|
|
28
|
+
pulse: {
|
|
29
|
+
type: 'opacity',
|
|
30
|
+
duration: 1500,
|
|
31
|
+
loop: true,
|
|
32
|
+
iterations: -1,
|
|
33
|
+
easing: 'ease-in-out',
|
|
34
|
+
direction: 'alternate',
|
|
35
|
+
delay: 0,
|
|
36
|
+
from: 1,
|
|
37
|
+
to: 0.4
|
|
38
|
+
},
|
|
39
|
+
/**
|
|
40
|
+
* Bouncing scale (attention grabber)
|
|
41
|
+
*/
|
|
42
|
+
bounce: {
|
|
43
|
+
type: 'scale',
|
|
44
|
+
duration: 600,
|
|
45
|
+
loop: true,
|
|
46
|
+
iterations: -1,
|
|
47
|
+
easing: 'bounce',
|
|
48
|
+
direction: 'alternate',
|
|
49
|
+
delay: 0,
|
|
50
|
+
from: 1,
|
|
51
|
+
to: 1.2
|
|
52
|
+
},
|
|
53
|
+
/**
|
|
54
|
+
* Horizontal shake (error/warning)
|
|
55
|
+
*/
|
|
56
|
+
shake: {
|
|
57
|
+
type: 'translate',
|
|
58
|
+
duration: 500,
|
|
59
|
+
loop: false,
|
|
60
|
+
iterations: 1,
|
|
61
|
+
easing: 'ease-out',
|
|
62
|
+
direction: 'normal',
|
|
63
|
+
delay: 0,
|
|
64
|
+
from: {
|
|
65
|
+
x: 0,
|
|
66
|
+
y: 0
|
|
67
|
+
},
|
|
68
|
+
to: {
|
|
69
|
+
x: 10,
|
|
70
|
+
y: 0
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
/**
|
|
74
|
+
* Ping effect (notification)
|
|
75
|
+
*/
|
|
76
|
+
ping: {
|
|
77
|
+
type: 'scale',
|
|
78
|
+
duration: 1000,
|
|
79
|
+
loop: true,
|
|
80
|
+
iterations: -1,
|
|
81
|
+
easing: 'ease-out',
|
|
82
|
+
direction: 'normal',
|
|
83
|
+
delay: 0,
|
|
84
|
+
from: 1,
|
|
85
|
+
to: 1.5
|
|
86
|
+
},
|
|
87
|
+
/**
|
|
88
|
+
* Quick wiggle (playful attention)
|
|
89
|
+
*/
|
|
90
|
+
wiggle: {
|
|
91
|
+
type: 'rotate',
|
|
92
|
+
duration: 300,
|
|
93
|
+
loop: false,
|
|
94
|
+
iterations: 1,
|
|
95
|
+
easing: 'ease-in-out',
|
|
96
|
+
direction: 'alternate',
|
|
97
|
+
delay: 0,
|
|
98
|
+
from: -15,
|
|
99
|
+
to: 15
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* Convert easing string to React Native Easing function
|
|
105
|
+
*/
|
|
106
|
+
export function getEasingFunction(easing) {
|
|
107
|
+
if (typeof easing === 'function') {
|
|
108
|
+
return easing;
|
|
109
|
+
}
|
|
110
|
+
switch (easing) {
|
|
111
|
+
case 'linear':
|
|
112
|
+
return Easing.linear;
|
|
113
|
+
case 'ease':
|
|
114
|
+
return Easing.ease;
|
|
115
|
+
case 'ease-in':
|
|
116
|
+
return Easing.in(Easing.ease);
|
|
117
|
+
case 'ease-out':
|
|
118
|
+
return Easing.out(Easing.ease);
|
|
119
|
+
case 'ease-in-out':
|
|
120
|
+
return Easing.inOut(Easing.ease);
|
|
121
|
+
case 'bounce':
|
|
122
|
+
return Easing.bounce;
|
|
123
|
+
default:
|
|
124
|
+
return Easing.linear;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* Resolve animation type to full configuration
|
|
130
|
+
*/
|
|
131
|
+
export function resolveAnimation(animation, overrides) {
|
|
132
|
+
// Get base config from preset or use custom config
|
|
133
|
+
const baseConfig = typeof animation === 'string' ? {
|
|
134
|
+
...ANIMATION_PRESETS[animation]
|
|
135
|
+
} : {
|
|
136
|
+
...animation
|
|
137
|
+
};
|
|
138
|
+
|
|
139
|
+
// Normalize from/to values
|
|
140
|
+
const rawFrom = baseConfig.from ?? 0;
|
|
141
|
+
const rawTo = baseConfig.to ?? 1;
|
|
142
|
+
|
|
143
|
+
// Normalize translate values to have required x/y
|
|
144
|
+
let normalizedFrom;
|
|
145
|
+
let normalizedTo;
|
|
146
|
+
if (baseConfig.type === 'translate') {
|
|
147
|
+
if (typeof rawFrom === 'number') {
|
|
148
|
+
normalizedFrom = {
|
|
149
|
+
x: rawFrom,
|
|
150
|
+
y: 0
|
|
151
|
+
};
|
|
152
|
+
} else {
|
|
153
|
+
normalizedFrom = {
|
|
154
|
+
x: rawFrom.x ?? 0,
|
|
155
|
+
y: rawFrom.y ?? 0
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
if (typeof rawTo === 'number') {
|
|
159
|
+
normalizedTo = {
|
|
160
|
+
x: rawTo,
|
|
161
|
+
y: 0
|
|
162
|
+
};
|
|
163
|
+
} else {
|
|
164
|
+
normalizedTo = {
|
|
165
|
+
x: rawTo.x ?? 0,
|
|
166
|
+
y: rawTo.y ?? 0
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
} else {
|
|
170
|
+
normalizedFrom = typeof rawFrom === 'number' ? rawFrom : 0;
|
|
171
|
+
normalizedTo = typeof rawTo === 'number' ? rawTo : 1;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
// Apply overrides
|
|
175
|
+
const config = {
|
|
176
|
+
type: baseConfig.type,
|
|
177
|
+
duration: overrides?.duration ?? baseConfig.duration ?? 1000,
|
|
178
|
+
loop: overrides?.loop ?? baseConfig.loop ?? true,
|
|
179
|
+
iterations: baseConfig.iterations ?? -1,
|
|
180
|
+
easing: overrides?.easing ?? baseConfig.easing ?? 'linear',
|
|
181
|
+
direction: baseConfig.direction ?? 'normal',
|
|
182
|
+
delay: overrides?.delay ?? baseConfig.delay ?? 0,
|
|
183
|
+
from: normalizedFrom,
|
|
184
|
+
to: normalizedTo
|
|
185
|
+
};
|
|
186
|
+
return config;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
/**
|
|
190
|
+
* Check if a string is a valid animation preset
|
|
191
|
+
*/
|
|
192
|
+
export function isAnimationPreset(value) {
|
|
193
|
+
return value in ANIMATION_PRESETS;
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
/**
|
|
197
|
+
* Get default duration for a preset
|
|
198
|
+
*/
|
|
199
|
+
export function getDefaultDuration(preset) {
|
|
200
|
+
return ANIMATION_PRESETS[preset]?.duration ?? 1000;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
/**
|
|
204
|
+
* Get default loop setting for a preset
|
|
205
|
+
*/
|
|
206
|
+
export function getDefaultLoop(preset) {
|
|
207
|
+
return ANIMATION_PRESETS[preset]?.loop ?? true;
|
|
208
|
+
}
|
|
209
|
+
//# sourceMappingURL=presets.js.map
|