AI-generated Key Takeaways
- 
          GMSNavigationTransactionRecorderenables recording of pickups and dropoffs for transactions, specifically for Mobility Services customers billed per transaction by Google.
- 
          It provides methods to record pickups and dropoffs, associating them with unique transaction IDs for billing purposes. 
- 
          A shared singleton instance should be accessed using sharedInstance, requiring prior initialization ofGMSServiceswith an API key.
- 
          It includes a utility for generating unique transaction IDs and requires all interactions to occur on the main thread. 
GMSNavigationTransactionRecorder
@interface GMSNavigationTransactionRecorder : NSObjectContains methods for recording transactions. This class should only be used if you are a Mobility Services customer and are billed by Google on a per-transaction basis.
- 
                  
                  Returns a shared singleton GMSNavigationTransactionRecorderinstance. This singleton is held weakly and may be deallocated if an application does not keep a strong reference. You must call this function only on the main thread.This method will throw an exception if GMSServices+provideAPIKey:has not been called.DeclarationSwift class func sharedInstance() -> GMSNavigationTransactionRecorderObjective-C + (nonnull GMSNavigationTransactionRecorder *)sharedInstance;
- 
                  
                  You should call this function each time a passenger or a delivery is picked up. You should populate the transactionIDs parameter with a unique ID for each transaction that applies to this event. You must call this function only on the main thread. This method should be called if and only if your company is billed by Google on a per-transaction basis. DeclarationSwift func recordPickup(at waypoint: GMSNavigationWaypoint?, forTransactionIDs transactionIDs: [String], withErrorHandler errorHandler: GMSNavigationTransactionRecorderErrorHandler? = nil)Objective-C - (void)recordPickupAtWaypoint:(nullable GMSNavigationWaypoint *)waypoint forTransactionIDs:(nonnull NSArray<NSString *> *)transactionIDs withErrorHandler: (nullable GMSNavigationTransactionRecorderErrorHandler) errorHandler;ParameterswaypointThe GMSNavigationWaypointat which the pickup is occurring, or nil if there was no guidance session leading to this pickup.transactionIDsOne or more transaction IDs to which this pickup applies. The transaction ID must be unique for each billable transaction. Transaction IDs must contain at least one and at most 64 characters. errorHandlerA block that will be invoked asynchronously on the main thread if an error occurs while recording the pickup. 
- 
                  
                  You should call this function each time a passenger is dropped-off or a delivery is delivered. You should populate the transactionIDs parameter with a unique ID for each transaction that applies to this event. You must call this function only on the main thread. This method should be called if and only if your company is billed by Google on a per-transaction basis. DeclarationSwift func recordDropoff(at waypoint: GMSNavigationWaypoint?, forTransactionIDs transactionIDs: [String], withErrorHandler errorHandler: GMSNavigationTransactionRecorderErrorHandler? = nil)Objective-C - (void)recordDropoffAtWaypoint:(nullable GMSNavigationWaypoint *)waypoint forTransactionIDs:(nonnull NSArray<NSString *> *)transactionIDs withErrorHandler: (nullable GMSNavigationTransactionRecorderErrorHandler) errorHandler;ParameterswaypointThe GMSNavigationWaypointat which the dropoff is occurring, or nil if there was no guidance session leading to this dropoff.transactionIDsOne or more transaction IDs to which this dropoff applies. The transaction ID must be unique for each billable transaction. Transaction IDs must contain at least one and at most 64 characters. errorHandlerA block that will be invoked asynchronously on the main thread if an error occurs while recording the dropoff. 
- 
                  
                  Generate a new unique transaction ID. DeclarationSwift class func generateTransactionID() -> StringObjective-C + (nonnull NSString *)generateTransactionID;
- 
                  
                  Unavailable Init is unavailable. Use +sharedInstance to acquire an instance. DeclarationObjective-C - (nonnull instancetype)init;