twilio-rn/modules/my-native-module/ios/MyNativeModule.swift

49 lines
1.8 KiB
Swift
Raw Normal View History

import ExpoModulesCore
public class MyNativeModule: Module {
// Each module class must implement the definition function. The definition consists of components
// that describes the module's functionality and behavior.
// See https://docs.expo.dev/modules/module-api for more details about available components.
public func definition() -> ModuleDefinition {
// Sets the name of the module that JavaScript code will use to refer to the module. Takes a string as an argument.
// Can be inferred from module's class name, but it's recommended to set it explicitly for clarity.
// The module will be accessible from `requireNativeModule('MyNativeModule')` in JavaScript.
Name("MyNativeModule")
// Defines constant property on the module.
Constant("PI") {
Double.pi
}
// Defines event names that the module can send to JavaScript.
Events("onChange")
// Defines a JavaScript synchronous function that runs the native code on the JavaScript thread.
Function("hello") {
return "Hello world! 👋"
}
// Defines a JavaScript function that always returns a Promise and whose native code
// is by default dispatched on the different thread than the JavaScript runtime runs on.
AsyncFunction("setValueAsync") { (value: String) in
// Send an event to JavaScript.
self.sendEvent("onChange", [
"value": value
])
}
// Enables the module to be used as a native view. Definition components that are accepted as part of the
// view definition: Prop, Events.
View(MyNativeModuleView.self) {
// Defines a setter for the `url` prop.
Prop("url") { (view: MyNativeModuleView, url: URL) in
if view.webView.url != url {
view.webView.load(URLRequest(url: url))
}
}
Events("onLoad")
}
}
}