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,175 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* createHeaderIcon - Helper for React Navigation header icons
|
|
3
|
+
* Creates header icons for headerLeft, headerRight, etc.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import React from 'react';
|
|
7
|
+
import { TouchableOpacity, StyleSheet } from 'react-native';
|
|
8
|
+
import { Icon } from '../alias';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Configuration for header icon
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Create a header icon component for React Navigation
|
|
16
|
+
*
|
|
17
|
+
* @example headerRight with back action
|
|
18
|
+
* ```tsx
|
|
19
|
+
* import { createHeaderIcon } from 'rn-iconify/navigation';
|
|
20
|
+
*
|
|
21
|
+
* <Stack.Screen
|
|
22
|
+
* name="Details"
|
|
23
|
+
* options={({ navigation }) => ({
|
|
24
|
+
* headerRight: createHeaderIcon({
|
|
25
|
+
* icon: 'mdi:close',
|
|
26
|
+
* onPress: () => navigation.goBack(),
|
|
27
|
+
* }),
|
|
28
|
+
* })}
|
|
29
|
+
* />
|
|
30
|
+
* ```
|
|
31
|
+
*
|
|
32
|
+
* @example headerLeft with menu
|
|
33
|
+
* ```tsx
|
|
34
|
+
* <Stack.Screen
|
|
35
|
+
* options={({ navigation }) => ({
|
|
36
|
+
* headerLeft: createHeaderIcon({
|
|
37
|
+
* icon: 'mdi:menu',
|
|
38
|
+
* onPress: () => navigation.openDrawer(),
|
|
39
|
+
* accessibilityLabel: 'Open menu',
|
|
40
|
+
* }),
|
|
41
|
+
* })}
|
|
42
|
+
* />
|
|
43
|
+
* ```
|
|
44
|
+
*
|
|
45
|
+
* @example Custom styling
|
|
46
|
+
* ```tsx
|
|
47
|
+
* <Stack.Screen
|
|
48
|
+
* options={{
|
|
49
|
+
* headerRight: createHeaderIcon({
|
|
50
|
+
* icon: 'mdi:dots-vertical',
|
|
51
|
+
* size: 28,
|
|
52
|
+
* color: '#007AFF',
|
|
53
|
+
* style: { marginRight: 8 },
|
|
54
|
+
* }),
|
|
55
|
+
* }}
|
|
56
|
+
* />
|
|
57
|
+
* ```
|
|
58
|
+
*/
|
|
59
|
+
export function createHeaderIcon(config) {
|
|
60
|
+
const {
|
|
61
|
+
icon,
|
|
62
|
+
size = 24,
|
|
63
|
+
color,
|
|
64
|
+
onPress,
|
|
65
|
+
style,
|
|
66
|
+
accessibilityLabel,
|
|
67
|
+
hitSlop = {
|
|
68
|
+
top: 10,
|
|
69
|
+
bottom: 10,
|
|
70
|
+
left: 10,
|
|
71
|
+
right: 10
|
|
72
|
+
}
|
|
73
|
+
} = config;
|
|
74
|
+
return function HeaderIcon(props) {
|
|
75
|
+
const iconColor = color ?? props.tintColor ?? '#000000';
|
|
76
|
+
const iconElement = /*#__PURE__*/React.createElement(Icon, {
|
|
77
|
+
name: icon,
|
|
78
|
+
size: size,
|
|
79
|
+
color: iconColor,
|
|
80
|
+
accessibilityLabel: accessibilityLabel
|
|
81
|
+
});
|
|
82
|
+
if (onPress) {
|
|
83
|
+
return /*#__PURE__*/React.createElement(TouchableOpacity, {
|
|
84
|
+
onPress: onPress,
|
|
85
|
+
style: [styles.container, style, {
|
|
86
|
+
padding: 8
|
|
87
|
+
}],
|
|
88
|
+
hitSlop: hitSlop,
|
|
89
|
+
accessibilityRole: "button",
|
|
90
|
+
accessibilityLabel: accessibilityLabel,
|
|
91
|
+
activeOpacity: props.pressOpacity ?? 0.7
|
|
92
|
+
}, iconElement);
|
|
93
|
+
}
|
|
94
|
+
return iconElement;
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* Create a back button icon for navigation headers
|
|
100
|
+
*
|
|
101
|
+
* @example
|
|
102
|
+
* ```tsx
|
|
103
|
+
* import { createBackIcon } from 'rn-iconify/navigation';
|
|
104
|
+
*
|
|
105
|
+
* <Stack.Screen
|
|
106
|
+
* options={({ navigation }) => ({
|
|
107
|
+
* headerLeft: createBackIcon({
|
|
108
|
+
* onPress: () => navigation.goBack(),
|
|
109
|
+
* }),
|
|
110
|
+
* })}
|
|
111
|
+
* />
|
|
112
|
+
* ```
|
|
113
|
+
*/
|
|
114
|
+
export function createBackIcon(options = {}) {
|
|
115
|
+
return createHeaderIcon({
|
|
116
|
+
icon: 'mdi:arrow-left',
|
|
117
|
+
accessibilityLabel: 'Go back',
|
|
118
|
+
...options
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* Create a close button icon for modal screens
|
|
124
|
+
*
|
|
125
|
+
* @example
|
|
126
|
+
* ```tsx
|
|
127
|
+
* import { createCloseIcon } from 'rn-iconify/navigation';
|
|
128
|
+
*
|
|
129
|
+
* <Stack.Screen
|
|
130
|
+
* options={({ navigation }) => ({
|
|
131
|
+
* headerRight: createCloseIcon({
|
|
132
|
+
* onPress: () => navigation.goBack(),
|
|
133
|
+
* }),
|
|
134
|
+
* })}
|
|
135
|
+
* />
|
|
136
|
+
* ```
|
|
137
|
+
*/
|
|
138
|
+
export function createCloseIcon(options = {}) {
|
|
139
|
+
return createHeaderIcon({
|
|
140
|
+
icon: 'mdi:close',
|
|
141
|
+
accessibilityLabel: 'Close',
|
|
142
|
+
...options
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* Create a menu button icon for opening drawers
|
|
148
|
+
*
|
|
149
|
+
* @example
|
|
150
|
+
* ```tsx
|
|
151
|
+
* import { createMenuIcon } from 'rn-iconify/navigation';
|
|
152
|
+
*
|
|
153
|
+
* <Stack.Screen
|
|
154
|
+
* options={({ navigation }) => ({
|
|
155
|
+
* headerLeft: createMenuIcon({
|
|
156
|
+
* onPress: () => navigation.openDrawer(),
|
|
157
|
+
* }),
|
|
158
|
+
* })}
|
|
159
|
+
* />
|
|
160
|
+
* ```
|
|
161
|
+
*/
|
|
162
|
+
export function createMenuIcon(options = {}) {
|
|
163
|
+
return createHeaderIcon({
|
|
164
|
+
icon: 'mdi:menu',
|
|
165
|
+
accessibilityLabel: 'Open menu',
|
|
166
|
+
...options
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
const styles = StyleSheet.create({
|
|
170
|
+
container: {
|
|
171
|
+
padding: 8
|
|
172
|
+
}
|
|
173
|
+
});
|
|
174
|
+
export default createHeaderIcon;
|
|
175
|
+
//# sourceMappingURL=createHeaderIcon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","TouchableOpacity","StyleSheet","Icon","createHeaderIcon","config","icon","size","color","onPress","style","accessibilityLabel","hitSlop","top","bottom","left","right","HeaderIcon","props","iconColor","tintColor","iconElement","createElement","name","styles","container","padding","accessibilityRole","activeOpacity","pressOpacity","createBackIcon","options","createCloseIcon","createMenuIcon","create"],"sourceRoot":"../../../src","sources":["navigation/createHeaderIcon.tsx"],"mappings":"AAAA;AACA;AACA;AACA;;AAEA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,gBAAgB,EAAEC,UAAU,QAAQ,cAAc;AAC3D,SAASC,IAAI,QAAQ,UAAU;;AAI/B;AACA;AACA;;AAuCA;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,OAAO,SAASC,gBAAgBA,CAACC,MAAwB,EAAE;EACzD,MAAM;IACJC,IAAI;IACJC,IAAI,GAAG,EAAE;IACTC,KAAK;IACLC,OAAO;IACPC,KAAK;IACLC,kBAAkB;IAClBC,OAAO,GAAG;MAAEC,GAAG,EAAE,EAAE;MAAEC,MAAM,EAAE,EAAE;MAAEC,IAAI,EAAE,EAAE;MAAEC,KAAK,EAAE;IAAG;EACvD,CAAC,GAAGX,MAAM;EAEV,OAAO,SAASY,UAAUA,CAACC,KAAsB,EAAE;IACjD,MAAMC,SAAS,GAAGX,KAAK,IAAIU,KAAK,CAACE,SAAS,IAAI,SAAS;IAEvD,MAAMC,WAAW,gBACfrB,KAAA,CAAAsB,aAAA,CAACnB,IAAI;MAACoB,IAAI,EAAEjB,IAAK;MAACC,IAAI,EAAEA,IAAK;MAACC,KAAK,EAAEW,SAAU;MAACR,kBAAkB,EAAEA;IAAmB,CAAE,CAC1F;IAED,IAAIF,OAAO,EAAE;MACX,oBACET,KAAA,CAAAsB,aAAA,CAACrB,gBAAgB;QACfQ,OAAO,EAAEA,OAAQ;QACjBC,KAAK,EAAE,CAACc,MAAM,CAACC,SAAS,EAAEf,KAAK,EAAE;UAAEgB,OAAO,EAAE;QAAE,CAAC,CAAE;QACjDd,OAAO,EAAEA,OAAQ;QACjBe,iBAAiB,EAAC,QAAQ;QAC1BhB,kBAAkB,EAAEA,kBAAmB;QACvCiB,aAAa,EAAEV,KAAK,CAACW,YAAY,IAAI;MAAI,GAExCR,WACe,CAAC;IAEvB;IAEA,OAAOA,WAAW;EACpB,CAAC;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASS,cAAcA,CAACC,OAAuC,GAAG,CAAC,CAAC,EAAE;EAC3E,OAAO3B,gBAAgB,CAAC;IACtBE,IAAI,EAAE,gBAAgB;IACtBK,kBAAkB,EAAE,SAAS;IAC7B,GAAGoB;EACL,CAAC,CAAC;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,eAAeA,CAACD,OAAuC,GAAG,CAAC,CAAC,EAAE;EAC5E,OAAO3B,gBAAgB,CAAC;IACtBE,IAAI,EAAE,WAAW;IACjBK,kBAAkB,EAAE,OAAO;IAC3B,GAAGoB;EACL,CAAC,CAAC;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASE,cAAcA,CAACF,OAAuC,GAAG,CAAC,CAAC,EAAE;EAC3E,OAAO3B,gBAAgB,CAAC;IACtBE,IAAI,EAAE,UAAU;IAChBK,kBAAkB,EAAE,WAAW;IAC/B,GAAGoB;EACL,CAAC,CAAC;AACJ;AAEA,MAAMP,MAAM,GAAGtB,UAAU,CAACgC,MAAM,CAAC;EAC/BT,SAAS,EAAE;IACTC,OAAO,EAAE;EACX;AACF,CAAC,CAAC;AAEF,eAAetB,gBAAgB","ignoreList":[]}
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* createTabBarIcon - Helper for React Navigation tab bar icons
|
|
3
|
+
* Creates a tabBarIcon function that handles focused/unfocused states
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import React from 'react';
|
|
7
|
+
import { Icon } from '../alias';
|
|
8
|
+
/**
|
|
9
|
+
* Normalize config to full TabBarIconConfig
|
|
10
|
+
*/
|
|
11
|
+
function normalizeConfig(config) {
|
|
12
|
+
// String: same icon for both states
|
|
13
|
+
if (typeof config === 'string') {
|
|
14
|
+
return {
|
|
15
|
+
focused: config
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
// Array: [focused, unfocused]
|
|
20
|
+
if (Array.isArray(config)) {
|
|
21
|
+
return {
|
|
22
|
+
focused: config[0],
|
|
23
|
+
unfocused: config[1]
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// Full config object
|
|
28
|
+
return config;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Create a tab bar icon function for React Navigation
|
|
33
|
+
*
|
|
34
|
+
* @example Simple usage (same icon for both states)
|
|
35
|
+
* ```tsx
|
|
36
|
+
* import { createTabBarIcon } from 'rn-iconify/navigation';
|
|
37
|
+
*
|
|
38
|
+
* <Tab.Screen
|
|
39
|
+
* name="Home"
|
|
40
|
+
* component={HomeScreen}
|
|
41
|
+
* options={{
|
|
42
|
+
* tabBarIcon: createTabBarIcon('mdi:home'),
|
|
43
|
+
* }}
|
|
44
|
+
* />
|
|
45
|
+
* ```
|
|
46
|
+
*
|
|
47
|
+
* @example Different icons for focused/unfocused
|
|
48
|
+
* ```tsx
|
|
49
|
+
* <Tab.Screen
|
|
50
|
+
* options={{
|
|
51
|
+
* tabBarIcon: createTabBarIcon(['mdi:home', 'mdi:home-outline']),
|
|
52
|
+
* }}
|
|
53
|
+
* />
|
|
54
|
+
* ```
|
|
55
|
+
*
|
|
56
|
+
* @example With full configuration
|
|
57
|
+
* ```tsx
|
|
58
|
+
* <Tab.Screen
|
|
59
|
+
* options={{
|
|
60
|
+
* tabBarIcon: createTabBarIcon({
|
|
61
|
+
* focused: 'mdi:home',
|
|
62
|
+
* unfocused: 'mdi:home-outline',
|
|
63
|
+
* size: 28,
|
|
64
|
+
* focusedColor: '#007AFF',
|
|
65
|
+
* }),
|
|
66
|
+
* }}
|
|
67
|
+
* />
|
|
68
|
+
* ```
|
|
69
|
+
*
|
|
70
|
+
* @example With aliases (requires IconAliasProvider)
|
|
71
|
+
* ```tsx
|
|
72
|
+
* <Tab.Screen
|
|
73
|
+
* options={{
|
|
74
|
+
* tabBarIcon: createTabBarIcon(['home', 'home-outline']),
|
|
75
|
+
* }}
|
|
76
|
+
* />
|
|
77
|
+
* ```
|
|
78
|
+
*/
|
|
79
|
+
export function createTabBarIcon(config) {
|
|
80
|
+
const normalizedConfig = normalizeConfig(config);
|
|
81
|
+
return function TabBarIcon({
|
|
82
|
+
focused,
|
|
83
|
+
color,
|
|
84
|
+
size
|
|
85
|
+
}) {
|
|
86
|
+
const {
|
|
87
|
+
focused: focusedIcon,
|
|
88
|
+
unfocused: unfocusedIcon,
|
|
89
|
+
size: customSize,
|
|
90
|
+
focusedColor,
|
|
91
|
+
unfocusedColor,
|
|
92
|
+
style,
|
|
93
|
+
accessibilityLabel
|
|
94
|
+
} = normalizedConfig;
|
|
95
|
+
|
|
96
|
+
// Determine which icon to show
|
|
97
|
+
const iconName = focused ? focusedIcon : unfocusedIcon ?? focusedIcon;
|
|
98
|
+
|
|
99
|
+
// Determine color
|
|
100
|
+
const iconColor = focused ? focusedColor ?? color : unfocusedColor ?? color;
|
|
101
|
+
|
|
102
|
+
// Determine size
|
|
103
|
+
const iconSize = customSize ?? size;
|
|
104
|
+
return /*#__PURE__*/React.createElement(Icon, {
|
|
105
|
+
name: iconName,
|
|
106
|
+
size: iconSize,
|
|
107
|
+
color: iconColor,
|
|
108
|
+
style: style,
|
|
109
|
+
accessibilityLabel: accessibilityLabel
|
|
110
|
+
});
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* Create multiple tab bar icons at once
|
|
116
|
+
*
|
|
117
|
+
* @example
|
|
118
|
+
* ```tsx
|
|
119
|
+
* import { createTabBarIcons } from 'rn-iconify/navigation';
|
|
120
|
+
*
|
|
121
|
+
* const tabIcons = createTabBarIcons({
|
|
122
|
+
* Home: ['mdi:home', 'mdi:home-outline'],
|
|
123
|
+
* Search: 'mdi:magnify',
|
|
124
|
+
* Profile: ['mdi:account', 'mdi:account-outline'],
|
|
125
|
+
* Settings: {
|
|
126
|
+
* focused: 'mdi:cog',
|
|
127
|
+
* unfocused: 'mdi:cog-outline',
|
|
128
|
+
* size: 26,
|
|
129
|
+
* },
|
|
130
|
+
* });
|
|
131
|
+
*
|
|
132
|
+
* <Tab.Screen
|
|
133
|
+
* name="Home"
|
|
134
|
+
* options={{ tabBarIcon: tabIcons.Home }}
|
|
135
|
+
* />
|
|
136
|
+
* ```
|
|
137
|
+
*/
|
|
138
|
+
export function createTabBarIcons(configs) {
|
|
139
|
+
const result = {};
|
|
140
|
+
for (const [key, config] of Object.entries(configs)) {
|
|
141
|
+
result[key] = createTabBarIcon(config);
|
|
142
|
+
}
|
|
143
|
+
return result;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* Quick helper for common tab patterns
|
|
148
|
+
* Uses filled/outline icon variants automatically
|
|
149
|
+
*
|
|
150
|
+
* @example
|
|
151
|
+
* ```tsx
|
|
152
|
+
* import { tabIcon } from 'rn-iconify/navigation';
|
|
153
|
+
*
|
|
154
|
+
* <Tab.Screen
|
|
155
|
+
* options={{
|
|
156
|
+
* tabBarIcon: tabIcon('mdi', 'home'), // mdi:home / mdi:home-outline
|
|
157
|
+
* }}
|
|
158
|
+
* />
|
|
159
|
+
* ```
|
|
160
|
+
*/
|
|
161
|
+
export function tabIcon(prefix, name, outlineSuffix = '-outline') {
|
|
162
|
+
return createTabBarIcon({
|
|
163
|
+
focused: `${prefix}:${name}`,
|
|
164
|
+
unfocused: `${prefix}:${name}${outlineSuffix}`
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
export default createTabBarIcon;
|
|
168
|
+
//# sourceMappingURL=createTabBarIcon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","Icon","normalizeConfig","config","focused","Array","isArray","unfocused","createTabBarIcon","normalizedConfig","TabBarIcon","color","size","focusedIcon","unfocusedIcon","customSize","focusedColor","unfocusedColor","style","accessibilityLabel","iconName","iconColor","iconSize","createElement","name","createTabBarIcons","configs","result","key","Object","entries","tabIcon","prefix","outlineSuffix"],"sourceRoot":"../../../src","sources":["navigation/createTabBarIcon.tsx"],"mappings":"AAAA;AACA;AACA;AACA;;AAEA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,IAAI,QAAQ,UAAU;AAQ/B;AACA;AACA;AACA,SAASC,eAAeA,CAACC,MAAiD,EAAoB;EAC5F;EACA,IAAI,OAAOA,MAAM,KAAK,QAAQ,EAAE;IAC9B,OAAO;MAAEC,OAAO,EAAED;IAAO,CAAC;EAC5B;;EAEA;EACA,IAAIE,KAAK,CAACC,OAAO,CAACH,MAAM,CAAC,EAAE;IACzB,OAAO;MAAEC,OAAO,EAAED,MAAM,CAAC,CAAC,CAAC;MAAEI,SAAS,EAAEJ,MAAM,CAAC,CAAC;IAAE,CAAC;EACrD;;EAEA;EACA,OAAOA,MAAM;AACf;;AAEA;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,OAAO,SAASK,gBAAgBA,CAC9BL,MAAiD,EAC7B;EACpB,MAAMM,gBAAgB,GAAGP,eAAe,CAACC,MAAM,CAAC;EAEhD,OAAO,SAASO,UAAUA,CAAC;IAAEN,OAAO;IAAEO,KAAK;IAAEC;EAAsB,CAAC,EAAE;IACpE,MAAM;MACJR,OAAO,EAAES,WAAW;MACpBN,SAAS,EAAEO,aAAa;MACxBF,IAAI,EAAEG,UAAU;MAChBC,YAAY;MACZC,cAAc;MACdC,KAAK;MACLC;IACF,CAAC,GAAGV,gBAAgB;;IAEpB;IACA,MAAMW,QAAQ,GAAGhB,OAAO,GAAGS,WAAW,GAAIC,aAAa,IAAID,WAAY;;IAEvE;IACA,MAAMQ,SAAS,GAAGjB,OAAO,GAAIY,YAAY,IAAIL,KAAK,GAAKM,cAAc,IAAIN,KAAM;;IAE/E;IACA,MAAMW,QAAQ,GAAGP,UAAU,IAAIH,IAAI;IAEnC,oBACEZ,KAAA,CAAAuB,aAAA,CAACtB,IAAI;MACHuB,IAAI,EAAEJ,QAAS;MACfR,IAAI,EAAEU,QAAS;MACfX,KAAK,EAAEU,SAAU;MACjBH,KAAK,EAAEA,KAAM;MACbC,kBAAkB,EAAEA;IAAmB,CACxC,CAAC;EAEN,CAAC;AACH;;AAEA;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,SAASM,iBAAiBA,CAE/BC,OAAU,EAA0C;EACpD,MAAMC,MAAM,GAAG,CAAC,CAA2C;EAE3D,KAAK,MAAM,CAACC,GAAG,EAAEzB,MAAM,CAAC,IAAI0B,MAAM,CAACC,OAAO,CAACJ,OAAO,CAAC,EAAE;IACnDC,MAAM,CAACC,GAAG,CAAY,GAAGpB,gBAAgB,CAACL,MAAM,CAAC;EACnD;EAEA,OAAOwB,MAAM;AACf;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASI,OAAOA,CACrBC,MAAc,EACdR,IAAY,EACZS,aAAa,GAAG,UAAU,EACN;EACpB,OAAOzB,gBAAgB,CAAC;IACtBJ,OAAO,EAAE,GAAG4B,MAAM,IAAIR,IAAI,EAAE;IAC5BjB,SAAS,EAAE,GAAGyB,MAAM,IAAIR,IAAI,GAAGS,aAAa;EAC9C,CAAC,CAAC;AACJ;AAEA,eAAezB,gBAAgB","ignoreList":[]}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* React Navigation Integration
|
|
3
|
+
* Helpers for using rn-iconify with React Navigation
|
|
4
|
+
*
|
|
5
|
+
* @example Tab Navigator
|
|
6
|
+
* ```tsx
|
|
7
|
+
* import { createTabBarIcon } from 'rn-iconify/navigation';
|
|
8
|
+
*
|
|
9
|
+
* <Tab.Navigator>
|
|
10
|
+
* <Tab.Screen
|
|
11
|
+
* name="Home"
|
|
12
|
+
* options={{
|
|
13
|
+
* tabBarIcon: createTabBarIcon(['mdi:home', 'mdi:home-outline']),
|
|
14
|
+
* }}
|
|
15
|
+
* />
|
|
16
|
+
* </Tab.Navigator>
|
|
17
|
+
* ```
|
|
18
|
+
*
|
|
19
|
+
* @example Drawer Navigator
|
|
20
|
+
* ```tsx
|
|
21
|
+
* import { createDrawerIcon } from 'rn-iconify/navigation';
|
|
22
|
+
*
|
|
23
|
+
* <Drawer.Screen
|
|
24
|
+
* options={{
|
|
25
|
+
* drawerIcon: createDrawerIcon('mdi:home'),
|
|
26
|
+
* }}
|
|
27
|
+
* />
|
|
28
|
+
* ```
|
|
29
|
+
*
|
|
30
|
+
* @example Header Icons
|
|
31
|
+
* ```tsx
|
|
32
|
+
* import { createHeaderIcon, createBackIcon } from 'rn-iconify/navigation';
|
|
33
|
+
*
|
|
34
|
+
* <Stack.Screen
|
|
35
|
+
* options={({ navigation }) => ({
|
|
36
|
+
* headerLeft: createBackIcon({ onPress: () => navigation.goBack() }),
|
|
37
|
+
* headerRight: createHeaderIcon({ icon: 'mdi:dots-vertical' }),
|
|
38
|
+
* })}
|
|
39
|
+
* />
|
|
40
|
+
* ```
|
|
41
|
+
*/
|
|
42
|
+
|
|
43
|
+
// Types
|
|
44
|
+
|
|
45
|
+
export { DEFAULT_NAVIGATION_PRESETS } from './types';
|
|
46
|
+
|
|
47
|
+
// Tab Bar Icons
|
|
48
|
+
export { createTabBarIcon, createTabBarIcons, tabIcon } from './createTabBarIcon';
|
|
49
|
+
|
|
50
|
+
// Drawer Icons
|
|
51
|
+
export { createDrawerIcon, createDrawerIcons } from './createDrawerIcon';
|
|
52
|
+
|
|
53
|
+
// Header Icons
|
|
54
|
+
export { createHeaderIcon, createBackIcon, createCloseIcon, createMenuIcon } from './createHeaderIcon';
|
|
55
|
+
// Hook
|
|
56
|
+
export { useNavigationIcon } from './useNavigationIcon';
|
|
57
|
+
// Default export
|
|
58
|
+
export { createTabBarIcon as default } from './createTabBarIcon';
|
|
59
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["DEFAULT_NAVIGATION_PRESETS","createTabBarIcon","createTabBarIcons","tabIcon","createDrawerIcon","createDrawerIcons","createHeaderIcon","createBackIcon","createCloseIcon","createMenuIcon","useNavigationIcon","default"],"sourceRoot":"../../../src","sources":["navigation/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;;AAEA;;AAeA,SAASA,0BAA0B,QAAQ,SAAS;;AAEpD;AACA,SAASC,gBAAgB,EAAEC,iBAAiB,EAAEC,OAAO,QAAQ,oBAAoB;;AAEjF;AACA,SAASC,gBAAgB,EAAEC,iBAAiB,QAAQ,oBAAoB;;AAExE;AACA,SACEC,gBAAgB,EAChBC,cAAc,EACdC,eAAe,EACfC,cAAc,QACT,oBAAoB;AAG3B;AACA,SAASC,iBAAiB,QAAQ,qBAAqB;AAGvD;AACA,SAAST,gBAAgB,IAAIU,OAAO,QAAQ,oBAAoB","ignoreList":[]}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* React Navigation Integration Types
|
|
3
|
+
* Type definitions for navigation icon helpers
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Props passed by React Navigation to tabBarIcon
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Props passed by React Navigation to drawerIcon
|
|
12
|
+
*/
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Props passed by React Navigation to headerLeft/headerRight icons
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Icon specification - can be a full name or alias
|
|
20
|
+
* @example 'mdi:home' or 'home' (if alias is registered)
|
|
21
|
+
*/
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Configuration for tab bar icon
|
|
25
|
+
*/
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Simple config - just icon names
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Configuration for drawer icon
|
|
33
|
+
*/
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Return type for createTabBarIcon
|
|
37
|
+
*/
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Return type for createDrawerIcon
|
|
41
|
+
*/
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Return type for createHeaderIcon
|
|
45
|
+
*/
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* Navigation icon preset - common icon patterns
|
|
49
|
+
*/
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* Default icon presets using popular icon sets
|
|
53
|
+
*/
|
|
54
|
+
export const DEFAULT_NAVIGATION_PRESETS = {
|
|
55
|
+
home: {
|
|
56
|
+
focused: 'mdi:home',
|
|
57
|
+
unfocused: 'mdi:home-outline'
|
|
58
|
+
},
|
|
59
|
+
search: {
|
|
60
|
+
focused: 'mdi:magnify',
|
|
61
|
+
unfocused: 'mdi:magnify'
|
|
62
|
+
},
|
|
63
|
+
profile: {
|
|
64
|
+
focused: 'mdi:account',
|
|
65
|
+
unfocused: 'mdi:account-outline'
|
|
66
|
+
},
|
|
67
|
+
settings: {
|
|
68
|
+
focused: 'mdi:cog',
|
|
69
|
+
unfocused: 'mdi:cog-outline'
|
|
70
|
+
},
|
|
71
|
+
notifications: {
|
|
72
|
+
focused: 'mdi:bell',
|
|
73
|
+
unfocused: 'mdi:bell-outline'
|
|
74
|
+
},
|
|
75
|
+
messages: {
|
|
76
|
+
focused: 'mdi:message',
|
|
77
|
+
unfocused: 'mdi:message-outline'
|
|
78
|
+
},
|
|
79
|
+
favorites: {
|
|
80
|
+
focused: 'mdi:heart',
|
|
81
|
+
unfocused: 'mdi:heart-outline'
|
|
82
|
+
},
|
|
83
|
+
cart: {
|
|
84
|
+
focused: 'mdi:cart',
|
|
85
|
+
unfocused: 'mdi:cart-outline'
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["DEFAULT_NAVIGATION_PRESETS","home","focused","unfocused","search","profile","settings","notifications","messages","favorites","cart"],"sourceRoot":"../../../src","sources":["navigation/types.ts"],"mappings":"AAAA;AACA;AACA;AACA;;AAKA;AACA;AACA;;AAOA;AACA;AACA;;AAOA;AACA;AACA;;AAOA;AACA;AACA;AACA;;AAGA;AACA;AACA;;AAwCA;AACA;AACA;;AAGA;AACA;AACA;;AAuBA;AACA;AACA;;AAGA;AACA;AACA;;AAGA;AACA;AACA;;AAGA;AACA;AACA;;AAYA;AACA;AACA;AACA,OAAO,MAAMA,0BAAgD,GAAG;EAC9DC,IAAI,EAAE;IAAEC,OAAO,EAAE,UAAU;IAAEC,SAAS,EAAE;EAAmB,CAAC;EAC5DC,MAAM,EAAE;IAAEF,OAAO,EAAE,aAAa;IAAEC,SAAS,EAAE;EAAc,CAAC;EAC5DE,OAAO,EAAE;IAAEH,OAAO,EAAE,aAAa;IAAEC,SAAS,EAAE;EAAsB,CAAC;EACrEG,QAAQ,EAAE;IAAEJ,OAAO,EAAE,SAAS;IAAEC,SAAS,EAAE;EAAkB,CAAC;EAC9DI,aAAa,EAAE;IAAEL,OAAO,EAAE,UAAU;IAAEC,SAAS,EAAE;EAAmB,CAAC;EACrEK,QAAQ,EAAE;IAAEN,OAAO,EAAE,aAAa;IAAEC,SAAS,EAAE;EAAsB,CAAC;EACtEM,SAAS,EAAE;IAAEP,OAAO,EAAE,WAAW;IAAEC,SAAS,EAAE;EAAoB,CAAC;EACnEO,IAAI,EAAE;IAAER,OAAO,EAAE,UAAU;IAAEC,SAAS,EAAE;EAAmB;AAC7D,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* useNavigationIcon - Hook for creating navigation icons
|
|
3
|
+
* Provides a clean API for creating icons with navigation context
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import React, { useMemo, useCallback } from 'react';
|
|
7
|
+
import { Icon } from '../alias';
|
|
8
|
+
|
|
9
|
+
// IconSpec is just a type alias for string (icon name)
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Hook options
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Return type for useNavigationIcon
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Hook for creating navigation icons with consistent styling
|
|
21
|
+
*
|
|
22
|
+
* @example Basic usage
|
|
23
|
+
* ```tsx
|
|
24
|
+
* import { useNavigationIcon } from 'rn-iconify/navigation';
|
|
25
|
+
*
|
|
26
|
+
* function MyTabs() {
|
|
27
|
+
* const { tabBarIcon, drawerIcon } = useNavigationIcon();
|
|
28
|
+
*
|
|
29
|
+
* return (
|
|
30
|
+
* <Tab.Navigator>
|
|
31
|
+
* <Tab.Screen
|
|
32
|
+
* name="Home"
|
|
33
|
+
* options={{
|
|
34
|
+
* tabBarIcon: tabBarIcon('mdi:home', 'mdi:home-outline'),
|
|
35
|
+
* }}
|
|
36
|
+
* />
|
|
37
|
+
* <Tab.Screen
|
|
38
|
+
* name="Settings"
|
|
39
|
+
* options={{
|
|
40
|
+
* tabBarIcon: tabBarIcon('mdi:cog'),
|
|
41
|
+
* }}
|
|
42
|
+
* />
|
|
43
|
+
* </Tab.Navigator>
|
|
44
|
+
* );
|
|
45
|
+
* }
|
|
46
|
+
* ```
|
|
47
|
+
*
|
|
48
|
+
* @example With auto-outline
|
|
49
|
+
* ```tsx
|
|
50
|
+
* const { autoTabBarIcon } = useNavigationIcon();
|
|
51
|
+
*
|
|
52
|
+
* <Tab.Screen
|
|
53
|
+
* options={{
|
|
54
|
+
* // Uses mdi:home (focused) and mdi:home-outline (unfocused)
|
|
55
|
+
* tabBarIcon: autoTabBarIcon('mdi', 'home'),
|
|
56
|
+
* }}
|
|
57
|
+
* />
|
|
58
|
+
* ```
|
|
59
|
+
*/
|
|
60
|
+
export function useNavigationIcon(options = {}) {
|
|
61
|
+
const {
|
|
62
|
+
defaultSize = 24,
|
|
63
|
+
outlineSuffix = '-outline'
|
|
64
|
+
} = options;
|
|
65
|
+
|
|
66
|
+
// Create tab bar icon function
|
|
67
|
+
const tabBarIcon = useCallback((focused, unfocused) => {
|
|
68
|
+
return ({
|
|
69
|
+
focused: isFocused,
|
|
70
|
+
color,
|
|
71
|
+
size
|
|
72
|
+
}) => {
|
|
73
|
+
const iconName = isFocused ? focused : unfocused ?? focused;
|
|
74
|
+
return /*#__PURE__*/React.createElement(Icon, {
|
|
75
|
+
name: iconName,
|
|
76
|
+
size: size ?? defaultSize,
|
|
77
|
+
color: color
|
|
78
|
+
});
|
|
79
|
+
};
|
|
80
|
+
}, [defaultSize]);
|
|
81
|
+
|
|
82
|
+
// Create drawer icon function
|
|
83
|
+
const drawerIcon = useCallback((icon, focusedIcon) => {
|
|
84
|
+
return ({
|
|
85
|
+
focused,
|
|
86
|
+
color,
|
|
87
|
+
size
|
|
88
|
+
}) => {
|
|
89
|
+
const iconName = focused && focusedIcon ? focusedIcon : icon;
|
|
90
|
+
return /*#__PURE__*/React.createElement(Icon, {
|
|
91
|
+
name: iconName,
|
|
92
|
+
size: size ?? defaultSize,
|
|
93
|
+
color: color
|
|
94
|
+
});
|
|
95
|
+
};
|
|
96
|
+
}, [defaultSize]);
|
|
97
|
+
|
|
98
|
+
// Create auto-outline tab bar icon
|
|
99
|
+
const autoTabBarIcon = useCallback((prefix, name) => {
|
|
100
|
+
const focused = `${prefix}:${name}`;
|
|
101
|
+
const unfocused = `${prefix}:${name}${outlineSuffix}`;
|
|
102
|
+
return tabBarIcon(focused, unfocused);
|
|
103
|
+
}, [tabBarIcon, outlineSuffix]);
|
|
104
|
+
|
|
105
|
+
// Render icon directly
|
|
106
|
+
const renderIcon = useCallback((name, props) => {
|
|
107
|
+
return /*#__PURE__*/React.createElement(Icon, {
|
|
108
|
+
name: name,
|
|
109
|
+
size: props.size ?? defaultSize,
|
|
110
|
+
color: props.color
|
|
111
|
+
});
|
|
112
|
+
}, [defaultSize]);
|
|
113
|
+
return useMemo(() => ({
|
|
114
|
+
tabBarIcon,
|
|
115
|
+
drawerIcon,
|
|
116
|
+
autoTabBarIcon,
|
|
117
|
+
renderIcon
|
|
118
|
+
}), [tabBarIcon, drawerIcon, autoTabBarIcon, renderIcon]);
|
|
119
|
+
}
|
|
120
|
+
export default useNavigationIcon;
|
|
121
|
+
//# sourceMappingURL=useNavigationIcon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","useMemo","useCallback","Icon","useNavigationIcon","options","defaultSize","outlineSuffix","tabBarIcon","focused","unfocused","isFocused","color","size","iconName","createElement","name","drawerIcon","icon","focusedIcon","autoTabBarIcon","prefix","renderIcon","props"],"sourceRoot":"../../../src","sources":["navigation/useNavigationIcon.tsx"],"mappings":"AAAA;AACA;AACA;AACA;;AAEA,OAAOA,KAAK,IAAIC,OAAO,EAAEC,WAAW,QAAQ,OAAO;AACnD,SAASC,IAAI,QAAQ,UAAU;;AAQ/B;;AAGA;AACA;AACA;;AAeA;AACA;AACA;;AAwBA;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,OAAO,SAASC,iBAAiBA,CAACC,OAAiC,GAAG,CAAC,CAAC,EAA2B;EACjG,MAAM;IAAEC,WAAW,GAAG,EAAE;IAAEC,aAAa,GAAG;EAAW,CAAC,GAAGF,OAAO;;EAEhE;EACA,MAAMG,UAAU,GAAGN,WAAW,CAC5B,CAACO,OAAiB,EAAEC,SAAoB,KAAyB;IAC/D,OAAO,CAAC;MAAED,OAAO,EAAEE,SAAS;MAAEC,KAAK;MAAEC;IAAsB,CAAC,KAAK;MAC/D,MAAMC,QAAQ,GAAGH,SAAS,GAAGF,OAAO,GAAIC,SAAS,IAAID,OAAQ;MAC7D,oBAAOT,KAAA,CAAAe,aAAA,CAACZ,IAAI;QAACa,IAAI,EAAEF,QAAS;QAACD,IAAI,EAAEA,IAAI,IAAIP,WAAY;QAACM,KAAK,EAAEA;MAAM,CAAE,CAAC;IAC1E,CAAC;EACH,CAAC,EACD,CAACN,WAAW,CACd,CAAC;;EAED;EACA,MAAMW,UAAU,GAAGf,WAAW,CAC5B,CAACgB,IAAc,EAAEC,WAAsB,KAAyB;IAC9D,OAAO,CAAC;MAAEV,OAAO;MAAEG,KAAK;MAAEC;IAAsB,CAAC,KAAK;MACpD,MAAMC,QAAQ,GAAGL,OAAO,IAAIU,WAAW,GAAGA,WAAW,GAAGD,IAAI;MAC5D,oBAAOlB,KAAA,CAAAe,aAAA,CAACZ,IAAI;QAACa,IAAI,EAAEF,QAAS;QAACD,IAAI,EAAEA,IAAI,IAAIP,WAAY;QAACM,KAAK,EAAEA;MAAM,CAAE,CAAC;IAC1E,CAAC;EACH,CAAC,EACD,CAACN,WAAW,CACd,CAAC;;EAED;EACA,MAAMc,cAAc,GAAGlB,WAAW,CAChC,CAACmB,MAAc,EAAEL,IAAY,KAAyB;IACpD,MAAMP,OAAO,GAAG,GAAGY,MAAM,IAAIL,IAAI,EAAE;IACnC,MAAMN,SAAS,GAAG,GAAGW,MAAM,IAAIL,IAAI,GAAGT,aAAa,EAAE;IACrD,OAAOC,UAAU,CAACC,OAAO,EAAEC,SAAS,CAAC;EACvC,CAAC,EACD,CAACF,UAAU,EAAED,aAAa,CAC5B,CAAC;;EAED;EACA,MAAMe,UAAU,GAAGpB,WAAW,CAC5B,CAACc,IAAc,EAAEO,KAAsC,KAAyB;IAC9E,oBAAOvB,KAAA,CAAAe,aAAA,CAACZ,IAAI;MAACa,IAAI,EAAEA,IAAK;MAACH,IAAI,EAAEU,KAAK,CAACV,IAAI,IAAIP,WAAY;MAACM,KAAK,EAAEW,KAAK,CAACX;IAAM,CAAE,CAAC;EAClF,CAAC,EACD,CAACN,WAAW,CACd,CAAC;EAED,OAAOL,OAAO,CACZ,OAAO;IACLO,UAAU;IACVS,UAAU;IACVG,cAAc;IACdE;EACF,CAAC,CAAC,EACF,CAACd,UAAU,EAAES,UAAU,EAAEG,cAAc,EAAEE,UAAU,CACrD,CAAC;AACH;AAEA,eAAelB,iBAAiB","ignoreList":[]}
|