코딩/React Native

[RN] react-native-maps AppDelegate.swift 설치문제

카슈밀 2025. 1. 31. 15:50
반응형

본 내용은 RN 0.77.0 버전에서 진행되어 작성되었습니다.

 

공식문서에는 0.73까지만 적용되는(?) AppDelegate.m으로(오브젝트 c) 적혀있어서  라이브러리 적용이 어려웠습니다.

 

이거때문에 하루 날림...짜증 -_-;;

 

위치 전문을 공개합니다.

// AppDelegate.swift

import UIKit
import React
import React_RCTAppDelegate
import ReactAppDependencyProvider
import GoogleMaps // 해당 내용 추가

@main
class AppDelegate: RCTAppDelegate {
  override func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey : Any]? = nil) -> Bool {
    GMSServices.provideAPIKey("구글api 키") // 해당 내용 추가
    self.moduleName = "어플이름"
    self.dependencyProvider = RCTAppDependencyProvider()

    // You can add your custom initial props in the dictionary below.
    // They will be passed down to the ViewController used by React Native.
    self.initialProps = [:]

    return super.application(application, didFinishLaunchingWithOptions: launchOptions)
  }

  override func sourceURL(for bridge: RCTBridge) -> URL? {
    self.bundleURL()
  }

  override func bundleURL() -> URL? {
#if DEBUG
    RCTBundleURLProvider.sharedSettings().jsBundleURL(forBundleRoot: "index")
#else
    Bundle.main.url(forResource: "main", withExtension: "jsbundle")
#endif
  }
}

 

# Resolve react_native_pods.rb with node to allow for hoisting
require Pod::Executable.execute_command('node', ['-p',
  'require.resolve(
    "react-native/scripts/react_native_pods.rb",
    {paths: [process.argv[1]]},
  )', __dir__]).strip

platform :ios, min_ios_version_supported
prepare_react_native_project!

linkage = ENV['USE_FRAMEWORKS']
if linkage != nil
  Pod::UI.puts "Configuring Pod with #{linkage}ally linked Frameworks".green
  use_frameworks! :linkage => linkage.to_sym
end

target '앱이름' do
  config = use_native_modules!
  
  // 해당 내용 추가
  rn_maps_path = '../node_modules/react-native-maps'
  pod 'react-native-google-maps', :path => rn_maps_path
  
  use_react_native!(
    :path => config[:reactNativePath],
    # An absolute path to your application root.
    :app_path => "#{Pod::Config.instance.installation_root}/.."
  )

  post_install do |installer|
    # https://github.com/facebook/react-native/blob/main/packages/react-native/scripts/react_native_pods.rb#L197-L202
    react_native_post_install(
      installer,
      config[:reactNativePath],
      :mac_catalyst_enabled => false,
      # :ccache_enabled => true
    )
  end
end

 

해당 작업 후 ios 폴더 내 pod install 진행.

 

안될경우 Podfile.lock, ios/build 파일 삭제 후 진행

 

 

https://github.com/react-native-maps/react-native-maps/blob/HEAD/docs/installation.md

 

react-native-maps/docs/installation.md at 02fe47720a22e84548beef669b93b7e33e5bfabf · react-native-maps/react-native-maps

React Native Mapview component for iOS + Android. Contribute to react-native-maps/react-native-maps development by creating an account on GitHub.

github.com

 

728x90