flutter_sms/ios/Classes/SwiftFlutterSmsPlugin.swift
2018-08-16 11:15:26 -04:00

40 lines
1.6 KiB
Swift

import Flutter
import UIKit
import MessageUI
public class SwiftFlutterSmsPlugin: NSObject, FlutterPlugin, UINavigationControllerDelegate, MFMessageComposeViewControllerDelegate {
var message = "Please Send Message"
var _arguments = [String: Any]()
public static func register(with registrar: FlutterPluginRegistrar) {
let channel = FlutterMethodChannel(name: "flutter_sms", binaryMessenger: registrar.messenger())
let instance = SwiftFlutterSmsPlugin()
registrar.addMethodCallDelegate(instance, channel: channel)
}
public func handle(_ call: FlutterMethodCall, result: @escaping FlutterResult) {
_arguments = call.arguments as! [String : Any];
switch call.method {
case "sendSMS":
#if targetEnvironment(simulator)
result(FlutterError(code: "message_not_sent", message: "Cannot send message on this device!", details: "Cannot send SMS and MMS on a Simulator. Test on a real device."))
#else
let controller = MFMessageComposeViewController()
controller.body = _arguments["message"] as? String
controller.recipients = _arguments["recipients"] as? [String]
controller.messageComposeDelegate = self
UIApplication.shared.keyWindow?.rootViewController?.present(controller, animated: true, completion: nil)
result(message)
#endif
default:
result(FlutterMethodNotImplemented)
break
}
}
public func messageComposeViewController(_ controller: MFMessageComposeViewController, didFinishWith result: MessageComposeResult) {
UIApplication.shared.keyWindow?.rootViewController?.dismiss(animated: true, completion: nil)
message = "Sent!"
}
}