foi retirado o expo, pois quando foi preciso estar gerando o apk release, o expo interferia na compilacao gerando erro e foi trocado para npm, pois com o yarn o jssip nao se comportava de maneira normal Generated by react-native@0.73.0dev-home
@ -0,0 +1,2 @@
|
||||
BUNDLE_PATH: "vendor/bundle" |
||||
BUNDLE_FORCE_RUBY_PLATFORM: 1 |
@ -0,0 +1,4 @@
|
||||
module.exports = { |
||||
root: true, |
||||
extends: '@react-native', |
||||
}; |
@ -0,0 +1,66 @@
|
||||
# OSX |
||||
# |
||||
.DS_Store |
||||
|
||||
# Xcode |
||||
# |
||||
build/ |
||||
*.pbxuser |
||||
!default.pbxuser |
||||
*.mode1v3 |
||||
!default.mode1v3 |
||||
*.mode2v3 |
||||
!default.mode2v3 |
||||
*.perspectivev3 |
||||
!default.perspectivev3 |
||||
xcuserdata |
||||
*.xccheckout |
||||
*.moved-aside |
||||
DerivedData |
||||
*.hmap |
||||
*.ipa |
||||
*.xcuserstate |
||||
ios/.xcode.env.local |
||||
|
||||
# Android/IntelliJ |
||||
# |
||||
build/ |
||||
.idea |
||||
.gradle |
||||
local.properties |
||||
*.iml |
||||
*.hprof |
||||
.cxx/ |
||||
*.keystore |
||||
!debug.keystore |
||||
|
||||
# node.js |
||||
# |
||||
node_modules/ |
||||
npm-debug.log |
||||
yarn-error.log |
||||
|
||||
# fastlane |
||||
# |
||||
# It is recommended to not store the screenshots in the git repo. Instead, use fastlane to re-generate the |
||||
# screenshots whenever they are needed. |
||||
# For more information about the recommended setup visit: |
||||
# https://docs.fastlane.tools/best-practices/source-control/ |
||||
|
||||
**/fastlane/report.xml |
||||
**/fastlane/Preview.html |
||||
**/fastlane/screenshots |
||||
**/fastlane/test_output |
||||
|
||||
# Bundle artifact |
||||
*.jsbundle |
||||
|
||||
# Ruby / CocoaPods |
||||
/ios/Pods/ |
||||
/vendor/bundle/ |
||||
|
||||
# Temporary files created by Metro to check the health of the file watcher |
||||
.metro-health-check* |
||||
|
||||
# testing |
||||
/coverage |
@ -0,0 +1,7 @@
|
||||
module.exports = { |
||||
arrowParens: 'avoid', |
||||
bracketSameLine: true, |
||||
bracketSpacing: false, |
||||
singleQuote: true, |
||||
trailingComma: 'all', |
||||
}; |
@ -0,0 +1,76 @@
|
||||
import ConfigScreen from './asset/screens/ConfigScreen/ConfigScreen'; |
||||
import JoinScreen from './asset/screens/JoinScreen/JoinScreen'; |
||||
import IncomingCallScreen from './asset/screens/IncomingScreen/IncomingScreen'; |
||||
import OutgoingCallScreen from './asset/screens/OutgoingScreen/OutgoingScreen'; |
||||
import ConferenceScreen from './asset/screens/ConferenceScreen/ConferenceScreen'; |
||||
import {NavigationContainer} from '@react-navigation/native'; |
||||
import { |
||||
createStackNavigator, |
||||
CardStyleInterpolators, |
||||
} from '@react-navigation/stack'; |
||||
import * as TextEncodingPolyfill from 'text-encoding'; |
||||
import BigInt from 'big-integer'; |
||||
import CombinedProvider from './asset/context/CombinedProvider'; |
||||
import React from 'react'; |
||||
|
||||
Object.assign(global, { |
||||
TextEncoder: TextEncodingPolyfill.TextEncoder, |
||||
TextDecoder: TextEncodingPolyfill.TextDecoder, |
||||
BigInt: BigInt, |
||||
}); |
||||
|
||||
export default function App() { |
||||
const Stack = createStackNavigator(); |
||||
|
||||
return ( |
||||
<NavigationContainer> |
||||
<CombinedProvider> |
||||
<Stack.Navigator initialRouteName="home"> |
||||
<Stack.Screen |
||||
name="home" |
||||
options={{ |
||||
headerShown: false, |
||||
cardStyleInterpolator: CardStyleInterpolators.forHorizontalIOS, |
||||
}} |
||||
component={JoinScreen} |
||||
/> |
||||
<Stack.Screen |
||||
name="configuracoes" |
||||
options={{ |
||||
headerShown: false, |
||||
cardStyleInterpolator: CardStyleInterpolators.forHorizontalIOS, |
||||
}} |
||||
component={ConfigScreen} |
||||
/> |
||||
<Stack.Screen |
||||
name="incomingCall" |
||||
options={{ |
||||
headerShown: false, |
||||
cardStyleInterpolator: |
||||
CardStyleInterpolators.forModalPresentationIOS, |
||||
}} |
||||
component={IncomingCallScreen} |
||||
/> |
||||
<Stack.Screen |
||||
name="outgoingCall" |
||||
options={{ |
||||
headerShown: false, |
||||
cardStyleInterpolator: |
||||
CardStyleInterpolators.forModalPresentationIOS, |
||||
}} |
||||
component={OutgoingCallScreen} |
||||
/> |
||||
<Stack.Screen |
||||
name="roomConference" |
||||
options={{ |
||||
headerShown: false, |
||||
cardStyleInterpolator: |
||||
CardStyleInterpolators.forModalPresentationIOS, |
||||
}} |
||||
component={ConferenceScreen} |
||||
/> |
||||
</Stack.Navigator> |
||||
</CombinedProvider> |
||||
</NavigationContainer> |
||||
); |
||||
} |
@ -0,0 +1,7 @@
|
||||
source 'https://rubygems.org' |
||||
|
||||
# You may use http://rbenv.org/ or https://rvm.io/ to install and use this version |
||||
ruby ">= 2.6.10" |
||||
|
||||
gem 'cocoapods', '~> 1.13' |
||||
gem 'activesupport', '>= 6.1.7.3', '< 7.1.0' |
@ -0,0 +1,79 @@
|
||||
This is a new [**React Native**](https://reactnative.dev) project, bootstrapped using [`@react-native-community/cli`](https://github.com/react-native-community/cli). |
||||
|
||||
# Getting Started |
||||
|
||||
>**Note**: Make sure you have completed the [React Native - Environment Setup](https://reactnative.dev/docs/environment-setup) instructions till "Creating a new application" step, before proceeding. |
||||
|
||||
## Step 1: Start the Metro Server |
||||
|
||||
First, you will need to start **Metro**, the JavaScript _bundler_ that ships _with_ React Native. |
||||
|
||||
To start Metro, run the following command from the _root_ of your React Native project: |
||||
|
||||
```bash |
||||
# using npm |
||||
npm start |
||||
|
||||
# OR using Yarn |
||||
yarn start |
||||
``` |
||||
|
||||
## Step 2: Start your Application |
||||
|
||||
Let Metro Bundler run in its _own_ terminal. Open a _new_ terminal from the _root_ of your React Native project. Run the following command to start your _Android_ or _iOS_ app: |
||||
|
||||
### For Android |
||||
|
||||
```bash |
||||
# using npm |
||||
npm run android |
||||
|
||||
# OR using Yarn |
||||
yarn android |
||||
``` |
||||
|
||||
### For iOS |
||||
|
||||
```bash |
||||
# using npm |
||||
npm run ios |
||||
|
||||
# OR using Yarn |
||||
yarn ios |
||||
``` |
||||
|
||||
If everything is set up _correctly_, you should see your new app running in your _Android Emulator_ or _iOS Simulator_ shortly provided you have set up your emulator/simulator correctly. |
||||
|
||||
This is one way to run your app — you can also run it directly from within Android Studio and Xcode respectively. |
||||
|
||||
## Step 3: Modifying your App |
||||
|
||||
Now that you have successfully run the app, let's modify it. |
||||
|
||||
1. Open `App.tsx` in your text editor of choice and edit some lines. |
||||
2. For **Android**: Press the <kbd>R</kbd> key twice or select **"Reload"** from the **Developer Menu** (<kbd>Ctrl</kbd> + <kbd>M</kbd> (on Window and Linux) or <kbd>Cmd ⌘</kbd> + <kbd>M</kbd> (on macOS)) to see your changes! |
||||
|
||||
For **iOS**: Hit <kbd>Cmd ⌘</kbd> + <kbd>R</kbd> in your iOS Simulator to reload the app and see your changes! |
||||
|
||||
## Congratulations! :tada: |
||||
|
||||
You've successfully run and modified your React Native App. :partying_face: |
||||
|
||||
### Now what? |
||||
|
||||
- If you want to add this new React Native code to an existing application, check out the [Integration guide](https://reactnative.dev/docs/integration-with-existing-apps). |
||||
- If you're curious to learn more about React Native, check out the [Introduction to React Native](https://reactnative.dev/docs/getting-started). |
||||
|
||||
# Troubleshooting |
||||
|
||||
If you can't get this to work, see the [Troubleshooting](https://reactnative.dev/docs/troubleshooting) page. |
||||
|
||||
# Learn More |
||||
|
||||
To learn more about React Native, take a look at the following resources: |
||||
|
||||
- [React Native Website](https://reactnative.dev) - learn more about React Native. |
||||
- [Getting Started](https://reactnative.dev/docs/environment-setup) - an **overview** of React Native and how setup your environment. |
||||
- [Learn the Basics](https://reactnative.dev/docs/getting-started) - a **guided tour** of the React Native **basics**. |
||||
- [Blog](https://reactnative.dev/blog) - read the latest official React Native **Blog** posts. |
||||
- [`@facebook/react-native`](https://github.com/facebook/react-native) - the Open Source; GitHub **repository** for React Native. |
@ -0,0 +1,17 @@
|
||||
/** |
||||
* @format |
||||
*/ |
||||
|
||||
import 'react-native'; |
||||
import React from 'react'; |
||||
import App from '../App'; |
||||
|
||||
// Note: import explicitly to use the types shipped with jest.
|
||||
import {it} from '@jest/globals'; |
||||
|
||||
// Note: test renderer must be required after react-native.
|
||||
import renderer from 'react-test-renderer'; |
||||
|
||||
it('renders correctly', () => { |
||||
renderer.create(<App />); |
||||
}); |
@ -0,0 +1,120 @@
|
||||
apply plugin: "com.android.application" |
||||
apply plugin: "org.jetbrains.kotlin.android" |
||||
apply plugin: "com.facebook.react" |
||||
|
||||
/** |
||||
* This is the configuration block to customize your React Native Android app. |
||||
* By default you don't need to apply any configuration, just uncomment the lines you need. |
||||
*/ |
||||
react { |
||||
/* Folders */ |
||||
// The root of your project, i.e. where "package.json" lives. Default is '..' |
||||
// root = file("../") |
||||
// The folder where the react-native NPM package is. Default is ../node_modules/react-native |
||||
// reactNativeDir = file("../node_modules/react-native") |
||||
// The folder where the react-native Codegen package is. Default is ../node_modules/@react-native/codegen |
||||
// codegenDir = file("../node_modules/@react-native/codegen") |
||||
// The cli.js file which is the React Native CLI entrypoint. Default is ../node_modules/react-native/cli.js |
||||
// cliFile = file("../node_modules/react-native/cli.js") |
||||
|
||||
/* Variants */ |
||||
// The list of variants to that are debuggable. For those we're going to |
||||
// skip the bundling of the JS bundle and the assets. By default is just 'debug'. |
||||
// If you add flavors like lite, prod, etc. you'll have to list your debuggableVariants. |
||||
// debuggableVariants = ["liteDebug", "prodDebug"] |
||||
|
||||
/* Bundling */ |
||||
// A list containing the node command and its flags. Default is just 'node'. |
||||
// nodeExecutableAndArgs = ["node"] |
||||
// |
||||
// The command to run when bundling. By default is 'bundle' |
||||
// bundleCommand = "ram-bundle" |
||||
// |
||||
// The path to the CLI configuration file. Default is empty. |
||||
// bundleConfig = file(../rn-cli.config.js) |
||||
// |
||||
// The name of the generated asset file containing your JS bundle |
||||
// bundleAssetName = "MyApplication.android.bundle" |
||||
// |
||||
// The entry file for bundle generation. Default is 'index.android.js' or 'index.js' |
||||
// entryFile = file("../js/MyApplication.android.js") |
||||
// |
||||
// A list of extra flags to pass to the 'bundle' commands. |
||||
// See https://github.com/react-native-community/cli/blob/main/docs/commands.md#bundle |
||||
// extraPackagerArgs = [] |
||||
|
||||
/* Hermes Commands */ |
||||
// The hermes compiler command to run. By default it is 'hermesc' |
||||
// hermesCommand = "$rootDir/my-custom-hermesc/bin/hermesc" |
||||
// |
||||
// The list of flags to pass to the Hermes compiler. By default is "-O", "-output-source-map" |
||||
// hermesFlags = ["-O", "-output-source-map"] |
||||
} |
||||
|
||||
/** |
||||
* Set this to true to Run Proguard on Release builds to minify the Java bytecode. |
||||
*/ |
||||
def enableProguardInReleaseBuilds = false |
||||
|
||||
/** |
||||
* The preferred build flavor of JavaScriptCore (JSC) |
||||
* |
||||
* For example, to use the international variant, you can use: |
||||
* `def jscFlavor = 'org.webkit:android-jsc-intl:+'` |
||||
* |
||||
* The international variant includes ICU i18n library and necessary data |
||||
* allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that |
||||
* give correct results when using with locales other than en-US. Note that |
||||
* this variant is about 6MiB larger per architecture than default. |
||||
*/ |
||||
def jscFlavor = 'org.webkit:android-jsc:+' |
||||
|
||||
android { |
||||
ndkVersion rootProject.ext.ndkVersion |
||||
buildToolsVersion rootProject.ext.buildToolsVersion |
||||
compileSdk rootProject.ext.compileSdkVersion |
||||
|
||||
namespace "com.sip" |
||||
defaultConfig { |
||||
applicationId "com.sip" |
||||
minSdkVersion rootProject.ext.minSdkVersion |
||||
targetSdkVersion rootProject.ext.targetSdkVersion |
||||
versionCode 1 |
||||
versionName "1.0" |
||||
} |
||||
signingConfigs { |
||||
debug { |
||||
storeFile file('debug.keystore') |
||||
storePassword 'android' |
||||
keyAlias 'androiddebugkey' |
||||
keyPassword 'android' |
||||
} |
||||
} |
||||
buildTypes { |
||||
debug { |
||||
signingConfig signingConfigs.debug |
||||
} |
||||
release { |
||||
// Caution! In production, you need to generate your own keystore file. |
||||
// see https://reactnative.dev/docs/signed-apk-android. |
||||
signingConfig signingConfigs.debug |
||||
minifyEnabled enableProguardInReleaseBuilds |
||||
proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" |
||||
} |
||||
} |
||||
} |
||||
|
||||
dependencies { |
||||
// The version of react-native is set by the React Native Gradle Plugin |
||||
implementation("com.facebook.react:react-android") |
||||
implementation("com.facebook.react:flipper-integration") |
||||
|
||||
if (hermesEnabled.toBoolean()) { |
||||
implementation("com.facebook.react:hermes-android") |
||||
} else { |
||||
implementation jscFlavor |
||||
} |
||||
} |
||||
|
||||
apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project) |
||||
apply from: file("../../node_modules/react-native-vector-icons/fonts.gradle") |
@ -0,0 +1,10 @@
|
||||
# Add project specific ProGuard rules here. |
||||
# By default, the flags in this file are appended to flags specified |
||||
# in /usr/local/Cellar/android-sdk/24.3.3/tools/proguard/proguard-android.txt |
||||
# You can edit the include path and order by changing the proguardFiles |
||||
# directive in build.gradle. |
||||
# |
||||
# For more details, see |
||||
# http://developer.android.com/guide/developing/tools/proguard.html |
||||
|
||||
# Add any project specific keep options here: |
@ -0,0 +1,9 @@
|
||||
<?xml version="1.0" encoding="utf-8"?> |
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" |
||||
xmlns:tools="http://schemas.android.com/tools"> |
||||
|
||||
<application |
||||
android:usesCleartextTraffic="true" |
||||
tools:targetApi="28" |
||||
tools:ignore="GoogleAppIndexingWarning"/> |
||||
</manifest> |
@ -0,0 +1,37 @@
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"> |
||||
|
||||
<uses-feature android:name="android.hardware.camera" /> |
||||
<uses-feature android:name="android.hardware.camera.autofocus" /> |
||||
<uses-feature android:name="android.hardware.audio.output" /> |
||||
<uses-feature android:name="android.hardware.microphone" /> |
||||
<uses-permission android:name="android.permission.CAMERA" /> |
||||
<uses-permission android:name="android.permission.RECORD_AUDIO" /> |
||||
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> |
||||
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> |
||||
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" /> |
||||
<uses-permission android:name="android.permission.INTERNET" /> |
||||
<uses-permission android:name="android.permission.WAKE_LOCK" /> |
||||
<uses-permission android:name="android.permission.BLUETOOTH" /> |
||||
<uses-permission android:name="android.permission.VIBRATE" /> |
||||
|
||||
<application |
||||
android:name=".MainApplication" |
||||
android:label="@string/app_name" |
||||
android:icon="@mipmap/logo_simples" |
||||
android:roundIcon="@mipmap/logo_simples_round" |
||||
android:allowBackup="false" |
||||
android:theme="@style/AppTheme"> |
||||
<activity |
||||
android:name=".MainActivity" |
||||
android:label="@string/app_name" |
||||
android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|screenSize|smallestScreenSize|uiMode" |
||||
android:launchMode="singleTask" |
||||
android:windowSoftInputMode="adjustResize" |
||||
android:exported="true"> |
||||
<intent-filter> |
||||
<action android:name="android.intent.action.MAIN" /> |
||||
<category android:name="android.intent.category.LAUNCHER" /> |
||||
</intent-filter> |
||||
</activity> |
||||
</application> |
||||
</manifest> |
@ -0,0 +1,29 @@
|
||||
package com.sip |
||||
|
||||
import com.facebook.react.ReactActivity |
||||
import com.facebook.react.ReactActivityDelegate |
||||
import com.facebook.react.defaults.DefaultNewArchitectureEntryPoint.fabricEnabled |
||||
import com.facebook.react.defaults.DefaultReactActivityDelegate |
||||
import android.os.Bundle; |
||||
|
||||
class MainActivity : ReactActivity() { |
||||
|
||||
/** |
||||
* Returns the name of the main component registered from JavaScript. This is used to schedule |
||||
* rendering of the component. |
||||
*/ |
||||
override fun getMainComponentName(): String = "sip" |
||||
|
||||
|
||||
//react-native-screens override |
||||
override fun onCreate(savedInstanceState: Bundle?) { |
||||
super.onCreate(null); |
||||
} |
||||
|
||||
/** |
||||
* Returns the instance of the [ReactActivityDelegate]. We use [DefaultReactActivityDelegate] |
||||
* which allows you to enable New Architecture with a single boolean flags [fabricEnabled] |
||||
*/ |
||||
override fun createReactActivityDelegate(): ReactActivityDelegate = |
||||
DefaultReactActivityDelegate(this, mainComponentName, fabricEnabled) |
||||
} |
@ -0,0 +1,45 @@
|
||||
package com.sip |
||||
|
||||
import android.app.Application |
||||
import com.facebook.react.PackageList |
||||
import com.facebook.react.ReactApplication |
||||
import com.facebook.react.ReactHost |
||||
import com.facebook.react.ReactNativeHost |
||||
import com.facebook.react.ReactPackage |
||||
import com.facebook.react.defaults.DefaultNewArchitectureEntryPoint.load |
||||
import com.facebook.react.defaults.DefaultReactHost.getDefaultReactHost |
||||
import com.facebook.react.defaults.DefaultReactNativeHost |
||||
import com.facebook.react.flipper.ReactNativeFlipper |
||||
import com.facebook.soloader.SoLoader |
||||
|
||||
class MainApplication : Application(), ReactApplication { |
||||
|
||||
override val reactNativeHost: ReactNativeHost = |
||||
object : DefaultReactNativeHost(this) { |
||||
override fun getPackages(): List<ReactPackage> { |
||||
// Packages that cannot be autolinked yet can be added manually here, for example: |
||||
// packages.add(new MyReactNativePackage()); |
||||
return PackageList(this).packages |
||||
} |
||||
|
||||
override fun getJSMainModuleName(): String = "index" |
||||
|
||||
override fun getUseDeveloperSupport(): Boolean = BuildConfig.DEBUG |
||||
|
||||
override val isNewArchEnabled: Boolean = BuildConfig.IS_NEW_ARCHITECTURE_ENABLED |
||||
override val isHermesEnabled: Boolean = BuildConfig.IS_HERMES_ENABLED |
||||
} |
||||
|
||||
override val reactHost: ReactHost |
||||
get() = getDefaultReactHost(this.applicationContext, reactNativeHost) |
||||
|
||||
override fun onCreate() { |
||||
super.onCreate() |
||||
SoLoader.init(this, false) |
||||
if (BuildConfig.IS_NEW_ARCHITECTURE_ENABLED) { |
||||
// If you opted-in for the New Architecture, we load the native entry point for this app. |
||||
load() |
||||
} |
||||
ReactNativeFlipper.initializeFlipper(this, reactNativeHost.reactInstanceManager) |
||||
} |
||||
} |
@ -0,0 +1,36 @@
|
||||
<?xml version="1.0" encoding="utf-8"?> |
||||
<!-- Copyright (C) 2014 The Android Open Source Project |
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License"); |
||||
you may not use this file except in compliance with the License. |
||||
You may obtain a copy of the License at |
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0 |
||||
|
||||
Unless required by applicable law or agreed to in writing, software |
||||
distributed under the License is distributed on an "AS IS" BASIS, |
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
See the License for the specific language governing permissions and |
||||
limitations under the License. |
||||
--> |
||||
<inset xmlns:android="http://schemas.android.com/apk/res/android" |
||||
android:insetLeft="@dimen/abc_edit_text_inset_horizontal_material" |
||||
android:insetRight="@dimen/abc_edit_text_inset_horizontal_material" |
||||
android:insetTop="@dimen/abc_edit_text_inset_top_material" |
||||
android:insetBottom="@dimen/abc_edit_text_inset_bottom_material"> |
||||
|
||||
<selector> |
||||
<!-- |
||||
This file is a copy of abc_edit_text_material (https://bit.ly/3k8fX7I). |
||||
The item below with state_pressed="false" and state_focused="false" causes a NullPointerException. |
||||
NullPointerException:tempt to invoke virtual method 'android.graphics.drawable.Drawable android.graphics.drawable.Drawable$ConstantState.newDrawable(android.content.res.Resources)' |
||||
|
||||
<item android:state_pressed="false" android:state_focused="false" android:drawable="@drawable/abc_textfield_default_mtrl_alpha"/> |
||||
|
||||
For more info, see https://bit.ly/3CdLStv (react-native/pull/29452) and https://bit.ly/3nxOMoR. |
||||
--> |
||||
<item android:state_enabled="false" android:drawable="@drawable/abc_textfield_default_mtrl_alpha"/> |
||||
<item android:drawable="@drawable/abc_textfield_activated_mtrl_alpha"/> |
||||
</selector> |
||||
|
||||
</inset> |
After Width: | Height: | Size: 3.0 KiB |
After Width: | Height: | Size: 4.9 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 2.0 KiB |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 4.5 KiB |
After Width: | Height: | Size: 6.9 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 6.3 KiB |
After Width: | Height: | Size: 10 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 9.0 KiB |
After Width: | Height: | Size: 15 KiB |
After Width: | Height: | Size: 249 KiB |
After Width: | Height: | Size: 249 KiB |
@ -0,0 +1,3 @@
|
||||
<resources> |
||||
<string name="app_name">SSimples</string> |
||||
</resources> |
@ -0,0 +1,9 @@
|
||||
<resources> |
||||
|
||||
<!-- Base application theme. --> |
||||
<style name="AppTheme" parent="Theme.AppCompat.DayNight.NoActionBar"> |
||||
<!-- Customize your theme here. --> |
||||
<item name="android:editTextBackground">@drawable/rn_edit_text_material</item> |
||||
</style> |
||||
|
||||
</resources> |
@ -0,0 +1,21 @@
|
||||
buildscript { |
||||
ext { |
||||
buildToolsVersion = "34.0.0" |
||||
minSdkVersion = 21 |
||||
compileSdkVersion = 34 |
||||
targetSdkVersion = 34 |
||||
ndkVersion = "25.1.8937393" |
||||
kotlinVersion = "1.8.0" |
||||
} |
||||
repositories { |
||||
google() |
||||
mavenCentral() |
||||
} |
||||
dependencies { |
||||
classpath("com.android.tools.build:gradle") |
||||
classpath("com.facebook.react:react-native-gradle-plugin") |
||||
classpath("org.jetbrains.kotlin:kotlin-gradle-plugin") |
||||
} |
||||
} |
||||
|
||||
apply plugin: "com.facebook.react.rootproject" |
@ -0,0 +1,41 @@
|
||||
# Project-wide Gradle settings. |
||||
|
||||
# IDE (e.g. Android Studio) users: |
||||
# Gradle settings configured through the IDE *will override* |
||||
# any settings specified in this file. |
||||
|
||||
# For more details on how to configure your build environment visit |
||||
# http://www.gradle.org/docs/current/userguide/build_environment.html |
||||
|
||||
# Specifies the JVM arguments used for the daemon process. |
||||
# The setting is particularly useful for tweaking memory settings. |
||||
# Default value: -Xmx512m -XX:MaxMetaspaceSize=256m |
||||
org.gradle.jvmargs=-Xmx2048m -XX:MaxMetaspaceSize=512m |
||||
|
||||
# When configured, Gradle will run in incubating parallel mode. |
||||
# This option should only be used with decoupled projects. More details, visit |
||||
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects |
||||
# org.gradle.parallel=true |
||||
|
||||
# AndroidX package structure to make it clearer which packages are bundled with the |
||||
# Android operating system, and which are packaged with your app's APK |
||||
# https://developer.android.com/topic/libraries/support-library/androidx-rn |
||||
android.useAndroidX=true |
||||
# Automatically convert third-party libraries to use AndroidX |
||||
android.enableJetifier=true |
||||
|
||||
# Use this property to specify which architecture you want to build. |
||||
# You can also override it from the CLI using |
||||
# ./gradlew <task> -PreactNativeArchitectures=x86_64 |
||||
reactNativeArchitectures=armeabi-v7a,arm64-v8a,x86,x86_64 |
||||
|
||||
# Use this property to enable support to the new architecture. |
||||
# This will allow you to use TurboModules and the Fabric render in |
||||
# your application. You should enable this flag either if you want |
||||
# to write custom TurboModules/Fabric components OR use libraries that |
||||
# are providing them. |
||||
newArchEnabled=false |
||||
|
||||
# Use this property to enable or disable the Hermes JS engine. |
||||
# If set to false, you will be using JSC instead. |
||||
hermesEnabled=true |
@ -0,0 +1,7 @@
|
||||
distributionBase=GRADLE_USER_HOME |
||||
distributionPath=wrapper/dists |
||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.3-all.zip |
||||
networkTimeout=10000 |
||||
validateDistributionUrl=true |
||||
zipStoreBase=GRADLE_USER_HOME |
||||
zipStorePath=wrapper/dists |
@ -0,0 +1,249 @@
|
||||
#!/bin/sh |
||||
|
||||
# |
||||
# Copyright © 2015-2021 the original authors. |
||||
# |
||||
# Licensed under the Apache License, Version 2.0 (the "License"); |
||||
# you may not use this file except in compliance with the License. |
||||
# You may obtain a copy of the License at |
||||
# |
||||
# https://www.apache.org/licenses/LICENSE-2.0 |
||||
# |
||||
# Unless required by applicable law or agreed to in writing, software |
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
# See the License for the specific language governing permissions and |
||||
# limitations under the License. |
||||
# |
||||
|
||||
############################################################################## |
||||
# |
||||
# Gradle start up script for POSIX generated by Gradle. |
||||
# |
||||
# Important for running: |
||||
# |
||||
# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is |
||||
# noncompliant, but you have some other compliant shell such as ksh or |
||||
# bash, then to run this script, type that shell name before the whole |
||||
# command line, like: |
||||
# |
||||
# ksh Gradle |
||||
# |
||||
# Busybox and similar reduced shells will NOT work, because this script |
||||
# requires all of these POSIX shell features: |
||||
# * functions; |
||||
# * expansions «$var», «${var}», «${var:-default}», «${var+SET}», |
||||
# «${var#prefix}», «${var%suffix}», and «$( cmd )»; |
||||
# * compound commands having a testable exit status, especially «case»; |
||||
# * various built-in commands including «command», «set», and «ulimit». |
||||
# |
||||
# Important for patching: |
||||
# |
||||
# (2) This script targets any POSIX shell, so it avoids extensions provided |
||||
# by Bash, Ksh, etc; in particular arrays are avoided. |
||||
# |
||||
# The "traditional" practice of packing multiple parameters into a |
||||
# space-separated string is a well documented source of bugs and security |
||||
# problems, so this is (mostly) avoided, by progressively accumulating |
||||
# options in "$@", and eventually passing that to Java. |
||||
# |
||||
# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS, |
||||
# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly; |
||||
# see the in-line comments for details. |
||||
# |
||||
# There are tweaks for specific operating systems such as AIX, CygWin, |
||||
# Darwin, MinGW, and NonStop. |
||||
# |
||||
# (3) This script is generated from the Groovy template |
||||
# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt |
||||
# within the Gradle project. |
||||
# |
||||
# You can find Gradle at https://github.com/gradle/gradle/. |
||||
# |
||||
############################################################################## |
||||
|
||||
# Attempt to set APP_HOME |
||||
|
||||
# Resolve links: $0 may be a link |
||||
app_path=$0 |
||||
|
||||
# Need this for daisy-chained symlinks. |
||||
while |
||||
APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path |
||||
[ -h "$app_path" ] |
||||
do |
||||
ls=$( ls -ld "$app_path" ) |
||||
link=${ls#*' -> '} |
||||
case $link in #( |
||||
/*) app_path=$link ;; #( |
||||
*) app_path=$APP_HOME$link ;; |
||||
esac |
||||
done |
||||
|
||||
# This is normally unused |
||||
# shellcheck disable=SC2034 |
||||
APP_BASE_NAME=${0##*/} |
||||
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036) |
||||
APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit |
||||
|
||||
# Use the maximum available, or set MAX_FD != -1 to use that value. |
||||
MAX_FD=maximum |
||||
|
||||
warn () { |
||||
echo "$*" |
||||
} >&2 |
||||
|
||||
die () { |
||||
echo |
||||
echo "$*" |
||||
echo |
||||
exit 1 |
||||
} >&2 |
||||
|
||||
# OS specific support (must be 'true' or 'false'). |
||||
cygwin=false |
||||
msys=false |
||||
darwin=false |
||||
nonstop=false |
||||
case "$( uname )" in #( |
||||
CYGWIN* ) cygwin=true ;; #( |
||||
Darwin* ) darwin=true ;; #( |
||||
MSYS* | MINGW* ) msys=true ;; #( |
||||
NONSTOP* ) nonstop=true ;; |
||||
esac |
||||
|
||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar |
||||
|
||||
|
||||
# Determine the Java command to use to start the JVM. |
||||
if [ -n "$JAVA_HOME" ] ; then |
||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then |
||||
# IBM's JDK on AIX uses strange locations for the executables |
||||
JAVACMD=$JAVA_HOME/jre/sh/java |
||||
else |
||||
JAVACMD=$JAVA_HOME/bin/java |
||||
fi |
||||
if [ ! -x "$JAVACMD" ] ; then |
||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME |
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the |
||||
location of your Java installation." |
||||
fi |
||||
else |
||||
JAVACMD=java |
||||
if ! command -v java >/dev/null 2>&1 |
||||
then |
||||
die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. |
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the |
||||
location of your Java installation." |
||||
fi |
||||
fi |
||||
|
||||
# Increase the maximum file descriptors if we can. |
||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then |
||||
case $MAX_FD in #( |
||||
max*) |
||||
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. |
||||
# shellcheck disable=SC3045 |
||||
MAX_FD=$( ulimit -H -n ) || |
||||
warn "Could not query maximum file descriptor limit" |
||||
esac |
||||
case $MAX_FD in #( |
||||
'' | soft) :;; #( |
||||
*) |
||||
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. |
||||
# shellcheck disable=SC3045 |
||||
ulimit -n "$MAX_FD" || |
||||
warn "Could not set maximum file descriptor limit to $MAX_FD" |
||||
esac |
||||
fi |
||||
|
||||
# Collect all arguments for the java command, stacking in reverse order: |
||||
# * args from the command line |
||||
# * the main class name |
||||
# * -classpath |
||||
# * -D...appname settings |
||||
# * --module-path (only if needed) |
||||
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. |
||||
|
||||
# For Cygwin or MSYS, switch paths to Windows format before running java |
||||
if "$cygwin" || "$msys" ; then |
||||
APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) |
||||
CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) |
||||
|
||||
JAVACMD=$( cygpath --unix "$JAVACMD" ) |
||||
|
||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh |
||||
for arg do |
||||
if |
||||
case $arg in #( |
||||
-*) false ;; # don't mess with options #( |
||||
/?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath |
||||
[ -e "$t" ] ;; #( |
||||
*) false ;; |
||||
esac |
||||
then |
||||
arg=$( cygpath --path --ignore --mixed "$arg" ) |
||||
fi |
||||
# Roll the args list around exactly as many times as the number of |
||||
# args, so each arg winds up back in the position where it started, but |
||||
# possibly modified. |
||||
# |
||||
# NB: a `for` loop captures its iteration list before it begins, so |
||||
# changing the positional parameters here affects neither the number of |
||||
# iterations, nor the values presented in `arg`. |
||||
shift # remove old arg |
||||
set -- "$@" "$arg" # push replacement arg |
||||
done |
||||
fi |
||||
|
||||
|
||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. |
||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' |
||||
|
||||
# Collect all arguments for the java command; |
||||
# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of |
||||
# shell script including quotes and variable substitutions, so put them in |
||||
# double quotes to make sure that they get re-expanded; and |
||||
# * put everything else in single quotes, so that it's not re-expanded. |
||||
|
||||
set -- \ |
||||
"-Dorg.gradle.appname=$APP_BASE_NAME" \ |
||||
-classpath "$CLASSPATH" \ |
||||
org.gradle.wrapper.GradleWrapperMain \ |
||||
"$@" |
||||
|
||||
# Stop when "xargs" is not available. |
||||
if ! command -v xargs >/dev/null 2>&1 |
||||
then |
||||
die "xargs is not available" |
||||
fi |
||||
|
||||
# Use "xargs" to parse quoted args. |
||||
# |
||||
# With -n1 it outputs one arg per line, with the quotes and backslashes removed. |
||||
# |
||||
# In Bash we could simply go: |
||||
# |
||||
# readarray ARGS < <( xargs -n1 <<<"$var" ) && |
||||
# set -- "${ARGS[@]}" "$@" |
||||
# |
||||
# but POSIX shell has neither arrays nor command substitution, so instead we |
||||
# post-process each arg (as a line of input to sed) to backslash-escape any |
||||
# character that might be a shell metacharacter, then use eval to reverse |
||||
# that process (while maintaining the separation between arguments), and wrap |
||||
# the whole thing up as a single "set" statement. |
||||
# |
||||
# This will of course break if any of these variables contains a newline or |
||||
# an unmatched quote. |
||||
# |
||||
|
||||
eval "set -- $( |
||||
printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | |
||||
xargs -n1 | |
||||
sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | |
||||
tr '\n' ' ' |
||||
)" '"$@"' |
||||
|
||||
exec "$JAVACMD" "$@" |
@ -0,0 +1,92 @@
|
||||
@rem |
||||
@rem Copyright 2015 the original author or authors. |
||||
@rem |
||||
@rem Licensed under the Apache License, Version 2.0 (the "License"); |
||||
@rem you may not use this file except in compliance with the License. |
||||
@rem You may obtain a copy of the License at |
||||
@rem |
||||
@rem https://www.apache.org/licenses/LICENSE-2.0 |
||||
@rem |
||||
@rem Unless required by applicable law or agreed to in writing, software |
||||
@rem distributed under the License is distributed on an "AS IS" BASIS, |
||||
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
@rem See the License for the specific language governing permissions and |
||||
@rem limitations under the License. |
||||
@rem |
||||
|
||||
@if "%DEBUG%"=="" @echo off |
||||
@rem ########################################################################## |
||||
@rem |
||||
@rem Gradle startup script for Windows |
||||
@rem |
||||
@rem ########################################################################## |
||||
|
||||
@rem Set local scope for the variables with windows NT shell |
||||
if "%OS%"=="Windows_NT" setlocal |
||||
|
||||
set DIRNAME=%~dp0 |
||||
if "%DIRNAME%"=="" set DIRNAME=. |
||||
@rem This is normally unused |
||||
set APP_BASE_NAME=%~n0 |
||||
set APP_HOME=%DIRNAME% |
||||
|
||||
@rem Resolve any "." and ".." in APP_HOME to make it shorter. |
||||
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi |
||||
|
||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. |
||||
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" |
||||
|
||||
@rem Find java.exe |
||||
if defined JAVA_HOME goto findJavaFromJavaHome |
||||
|
||||
set JAVA_EXE=java.exe |
||||
%JAVA_EXE% -version >NUL 2>&1 |
||||
if %ERRORLEVEL% equ 0 goto execute |
||||
|
||||
echo. |
||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. |
||||
echo. |
||||
echo Please set the JAVA_HOME variable in your environment to match the |
||||
echo location of your Java installation. |
||||
|
||||
goto fail |
||||
|
||||
:findJavaFromJavaHome |
||||
set JAVA_HOME=%JAVA_HOME:"=% |
||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe |
||||
|
||||
if exist "%JAVA_EXE%" goto execute |
||||
|
||||
echo. |
||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% |
||||
echo. |
||||
echo Please set the JAVA_HOME variable in your environment to match the |
||||
echo location of your Java installation. |
||||
|
||||
goto fail |
||||
|
||||
:execute |
||||
@rem Setup the command line |
||||
|
||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar |
||||
|
||||
|
||||
@rem Execute Gradle |
||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* |
||||
|
||||
:end |
||||
@rem End local scope for the variables with windows NT shell |
||||
if %ERRORLEVEL% equ 0 goto mainEnd |
||||
|
||||
:fail |
||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of |
||||
rem the _cmd.exe /c_ return code! |
||||
set EXIT_CODE=%ERRORLEVEL% |
||||
if %EXIT_CODE% equ 0 set EXIT_CODE=1 |
||||
if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% |
||||
exit /b %EXIT_CODE% |
||||
|
||||
:mainEnd |
||||
if "%OS%"=="Windows_NT" endlocal |
||||
|
||||
:omega |
@ -0,0 +1,4 @@
|
||||
rootProject.name = 'sip' |
||||
apply from: file("../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesSettingsGradle(settings) |
||||
include ':app' |
||||
includeBuild('../node_modules/@react-native/gradle-plugin') |
@ -0,0 +1,68 @@
|
||||
import React, {createContext, useState, useEffect, useMemo} from 'react'; |
||||
// import * as SecureStore from 'expo-secure-store';
|
||||
|
||||
export const AuthContext = createContext(); |
||||
|
||||
export const AuthProvider = ({children}) => { |
||||
const [sendAuth, setSendAuth] = useState(false); |
||||
const [authData, setAuthData] = useState({ |
||||
servidor: '', |
||||
porta: '', |
||||
ramal: '', |
||||
username: '', |
||||
senha: '', |
||||
}); |
||||
|
||||
// const save = async (key, value) => {
|
||||
// try {
|
||||
// await SecureStore.setItemAsync(key, JSON.stringify(value));
|
||||
// console.log(`Dados salvos com sucesso para a chave ${key}`);
|
||||
// } catch (error) {
|
||||
// console.error('Erro ao salvar os dados:', error);
|
||||
// }
|
||||
// };
|
||||
|
||||
// useEffect(() => {
|
||||
// const fetchData = async () => {
|
||||
// try {
|
||||
// const savedAuthData = await SecureStore.getItemAsync('authData');
|
||||
// if (savedAuthData) {
|
||||
// setAuthData(JSON.parse(savedAuthData));
|
||||
// //Caso tenha dados salvos ele ja tenta logar
|
||||
// setSendAuth(prevState => !prevState);
|
||||
// }
|
||||
// } catch (error) {
|
||||
// console.error('Erro ao recuperar os dados salvos:', error);
|
||||
// }
|
||||
// };
|
||||
|
||||
// fetchData();
|
||||
// }, []);
|
||||
|
||||
const handleInputChange = (field, value) => { |
||||
setAuthData(prevAuthData => ({ |
||||
...prevAuthData, |
||||
[field]: value, |
||||
})); |
||||
}; |
||||
const handleSubmit = () => { |
||||
// save('authData', authData);
|
||||
setSendAuth(prevState => !prevState); |
||||
}; |
||||
|
||||
const contextValues = useMemo( |
||||
() => ({ |
||||
authData, |
||||
handleInputChange, |
||||
handleSubmit, |
||||
sendAuth, |
||||
}), |
||||
[authData, sendAuth], |
||||
); |
||||
|
||||
return ( |
||||
<AuthContext.Provider value={contextValues}> |
||||
{children} |
||||
</AuthContext.Provider> |
||||
); |
||||
}; |
@ -0,0 +1,460 @@
|
||||
import React, { |
||||
createContext, |
||||
useState, |
||||
useEffect, |
||||
useRef, |
||||
useMemo, |
||||
useContext, |
||||
} from 'react'; |
||||
import {StackActions, useNavigation} from '@react-navigation/native'; |
||||
import InCallManager from 'react-native-incall-manager'; |
||||
import JsSIP from 'react-native-jssip'; |
||||
import {Alert} from 'react-native'; |
||||
import {AuthContext} from './AuthContext'; |
||||
|
||||
export const CallContext = createContext(); |
||||
|
||||
export const CallProvider = ({children}) => { |
||||
const {authData, sendAuth} = useContext(AuthContext); |
||||
const navigation = useNavigation(); |
||||
const [session, setSession] = useState(null); |
||||
const [ua, setUa] = useState(null); |
||||
const [incommingCaller, setIncommingCaller] = useState(null); |
||||
const [calle, setCalle] = useState(null); |
||||
const [localMicOn, setLocalMicOn] = useState(true); |
||||
const [localWebcamOn, setLocalWebcamOn] = useState(true); |
||||
const [localStream, setLocalStream] = useState(null); |
||||
const [remoteStream, setRemoteStream] = useState(null); |
||||
const peerConnectionRef = useRef(null); |
||||
const [status, setStatus] = useState('disconectado'); |
||||
const [statusColor, setStatusColor] = useState('black'); |
||||
const [currentAlert, setCurrentAlert] = useState(null); |
||||
|
||||
const controlStatus = status => { |
||||
switch (status) { |
||||
case 'registrado': |
||||
return 'green'; |
||||
case 'naoRegistrado': |
||||
return 'gray'; |
||||
case 'falhaRegistro': |
||||
return 'red'; |
||||
default: |
||||
return 'gray'; |
||||
} |
||||
}; |
||||
|
||||
useEffect(() => { |
||||
console.log(status); |
||||
setStatusColor(controlStatus(status)); |
||||
}, [status]); |
||||
|
||||
useEffect(() => { |
||||
console.log('Verificando authData:', authData); |
||||
if ( |
||||
authData.servidor && |
||||
authData.porta && |
||||
authData.ramal && |
||||
authData.senha && |
||||
authData.username |
||||
) { |
||||
console.log('SetupPhone iniciado'); |
||||
setupPhone(authData); |
||||
} |
||||
return () => { |
||||
console.log('Cleanup iniciado'); |
||||
cleanup(); |
||||
}; |
||||
}, [sendAuth]); |
||||
|
||||
const setupPhone = authData => { |
||||
const {servidor, porta, ramal, senha, username} = authData; |
||||
|
||||
const socket = new JsSIP.WebSocketInterface( |
||||
`${'ws'}://${servidor}:${porta}/ws`, |
||||
); |
||||
const configuration = { |
||||
uri: `sip:${ramal}@${servidor}`, |
||||
password: senha, |
||||
sockets: [socket], |
||||
session_timers: false, |
||||
no_answer_timeout: 180, |
||||
hack_via_tcp: false, |
||||
hack_via_ws: true, |
||||
display_name: username !== null ? username : ramal, |
||||
user_agent: 'Softphone React Native', |
||||
contact_uri: `sip:${ramal}@${servidor};transport=${'ws'}`, |
||||
pcConfig: { |
||||
iceServers: [ |
||||
{urls: 'stun:stun.l.google.com:19302'}, |
||||
{urls: 'stun:stun1.l.google.com:19302'}, |
||||
{urls: 'stun:stun2.l.google.com:19302'}, |
||||
{ |
||||
urls: 'turn:relay1.expressturn.com:3478', |
||||
username: 'efBWA92I6LHKOAISP4', |
||||
credential: 'WrVpk6pHeaKzMkAa', |
||||
}, |
||||
], |
||||
}, |
||||
}; |
||||
|
||||
const phone = new JsSIP.UA(configuration); |
||||
|
||||
phone.on('registrationFailed', function (ev) { |
||||
console.log('Registering on SIP server failed with error: ' + ev.cause); |
||||
configuration.uri = null; |
||||
configuration.password = null; |
||||
}); |
||||
|
||||
phone.on('newRTCSession', ev => { |
||||
const newSession = ev.session; |
||||
//Para quando estou criando uma conexao, ou seja, estou realizando uma ligacao
|
||||
if (newSession.connection) { |
||||
peerConnectionRef.current = newSession.connection; |
||||
console.log('criou peerConnection', peerConnectionRef.current); |
||||
} |
||||
//Para quando estou recebendo uma conexao
|
||||
newSession.on('peerconnection', event => { |
||||
peerConnectionRef.current = event.peerconnection; |
||||
console.log('recebeu o peerConnection', peerConnectionRef.current); |
||||
}); |
||||
// RECEBENDO UMA CHAMADA
|
||||
if (newSession.direction === 'incoming') { |
||||
navigation.dispatch(StackActions.replace('incomingCall')); |
||||
setIncommingCaller(newSession.remote_identity.uri.user); |
||||
InCallManager.startRingtone('_BUNDLE_', [0, 1000, 500, 1000]); |
||||
// Quando finalizar a chamada
|
||||
newSession.on('ended', () => { |
||||
navigation.dispatch(StackActions.replace('home')); |
||||
setSession(null); |
||||
setRemoteStream(null); |
||||
setIncommingCaller(null); |
||||
if (peerConnectionRef.current) { |
||||
peerConnectionRef.current.close(); |
||||
peerConnectionRef.current = null; |
||||
} |
||||
// Parar o InCallManager e o ringtone quando a chamada termina
|
||||
InCallManager.stop(); |
||||
InCallManager.stopRingtone(); |
||||
}); |
||||
// QUANDO UMA CHAMADA APRESENTAR PROBLEMAS
|
||||
newSession.on('failed', () => { |
||||
setRemoteStream(null); |
||||
setSession(null); |
||||
setIncommingCaller(null); |
||||
navigation.dispatch(StackActions.replace('home')); |
||||
if (peerConnectionRef.current) { |
||||
peerConnectionRef.current.close(); |
||||
peerConnectionRef.current = null; |
||||
} |
||||
// Parar o InCallManager e o ringtone quando a chamada falha
|
||||
InCallManager.stop(); |
||||
InCallManager.stopRingtone(); |
||||
}); |
||||
} else { |
||||
// Quando finalizar a chamada
|
||||
newSession.on('ended', () => { |
||||
navigation.dispatch(StackActions.popToTop()); |
||||
setRemoteStream(null); |
||||
setSession(null); |
||||
// Parar o InCallManager quando a chamada termina
|
||||
InCallManager.stop(); |
||||
}); |
||||
// QUANDO UMA CHAMADA APRESENTAR PROBLEMAS
|
||||
newSession.on('failed', () => { |
||||
navigation.dispatch(StackActions.popToTop()); |
||||
setRemoteStream(null); |
||||
setSession(null); |
||||
// Parar o InCallManager quando a chamada falha
|
||||
InCallManager.stop(); |
||||
}); |
||||
} |
||||
newSession.on('confirmed', async () => { |
||||
if (peerConnectionRef.current) { |
||||
captureMidias(); |
||||
} |
||||
}); |
||||
newSession.on('newDTMF', function (event) { |
||||
console.log('DTMF recebido:', event.dtmf.tone); |
||||
}); |
||||
newSession.on('icecandidate', function (event) { |
||||
if ( |
||||
event.candidate.type === 'srflx' && |
||||
event.candidate.relatedAddress !== null && |
||||
event.candidate.relatedPort !== null |
||||
) { |
||||
event.ready(); |
||||
} |
||||
}); |
||||
// Atribuir uma nova sessao assim que estabelcer uma
|
||||
setSession(newSession); |
||||
}); |
||||
phone.on('registered', function (e) { |
||||
setStatus('registrado'); |
||||
if (currentAlert === null || currentAlert !== 'registrado') { |
||||
setCurrentAlert('registrado'); |
||||
Alert.alert( |
||||
'Ramal registrado!', |
||||
'Seu ramal foi registrado no servidor e está pronto para uso.', |
||||
[ |
||||
{ |
||||
text: 'Ok', |
||||
onPress: () => setCurrentAlert(null), |
||||
}, |
||||
], |
||||
); |
||||
} |
||||
}); |
||||
|
||||
phone.on('unregistered', function (e) { |
||||
setStatus('naoRegistrado'); |
||||
if (currentAlert === null || currentAlert !== 'naoRegistrado') { |
||||
setCurrentAlert('naoRegistrado'); |
||||
Alert.alert('Não foi possível conectar-se ao servidor!', '', [ |
||||
{ |
||||
text: 'Ok', |
||||
onPress: () => setCurrentAlert(null), |
||||
}, |
||||
]); |
||||
} |
||||
}); |
||||
|
||||
phone.on('registrationFailed', function (e) { |
||||
setStatus('falhaRegistro'); |
||||
if (currentAlert === null || currentAlert !== 'falhaRegistro') { |
||||
setCurrentAlert('falhaRegistro'); |
||||
Alert.alert( |
||||
'Erro ao registrar ramal!', |
||||
'Confira suas credenciais de registro e tente novamente.', |
||||
[ |
||||
{ |
||||
text: 'Ok', |
||||
onPress: () => setCurrentAlert(null), |
||||
}, |
||||
], |
||||
); |
||||
} |
||||
}); |
||||
phone.start(); |
||||
setUa(phone); |
||||
}; |
||||
const cleanup = () => { |
||||
if (peerConnectionRef.current) { |
||||
peerConnectionRef.current.close(); |
||||
peerConnectionRef.current = null; |
||||
} |
||||
if (localStream) { |
||||
localStream.getTracks().forEach(track => track.stop()); |
||||
} |
||||
if (remoteStream) { |
||||
remoteStream.getTracks().forEach(track => track.stop()); |
||||
} |
||||
if (ua) { |
||||
ua.stop(); |
||||
} |
||||
}; |
||||
const handleAceitarChamada = async () => { |
||||
try { |
||||
if (session) { |
||||
session.answer({ |
||||
//Defino ao JsSIP se quero que ele capture as midias de audio e video
|
||||
mediaConstraints: { |
||||
audio: true, |
||||
video: true, |
||||
}, |
||||
}); |
||||
// Parar o ringtone quando a chamada é aceita
|
||||
InCallManager.stopRingtone(); |
||||
// Iniciar o InCallManager quando uma chamada é aceita
|
||||
InCallManager.start({media: 'audio'}); |
||||
navigation.dispatch(StackActions.replace('roomConference')); |
||||
} |
||||
} catch (error) { |
||||
console.error('Failed to accept call:', error); |
||||
} |
||||
}; |
||||
|
||||
const handleEndCall = async () => { |
||||
if (session) { |
||||
session.terminate(); |
||||
setSession(null); |
||||
setIncommingCaller(null); |
||||
InCallManager.stopRingback(); |
||||
InCallManager.stopRingtone(); |
||||
InCallManager.stop(); |
||||
navigation.dispatch(StackActions.replace('home')); |
||||
} else { |
||||
navigation.dispatch(StackActions.replace('home')); |
||||
} |
||||
}; |
||||
const handleIniciarChamada = async () => { |
||||
try { |
||||
if (ua && calle) { |
||||
const eventHandlers = { |
||||
progress: () => { |
||||
console.log('Call is in progress'); |
||||
// Iniciar o ringback quando a chamada está em progresso
|
||||
InCallManager.start({media: 'audio', ringback: '_DTMF_'}); |
||||
console.log('CHAMOU INCALL START 3'); |
||||
}, |
||||
failed: e => { |
||||
console.log('Call failed with cause: ' + e.cause); |
||||
if (peerConnectionRef.current) { |
||||
peerConnectionRef.current.close(); |
||||
peerConnectionRef.current = null; |
||||
} |
||||
// Parar o InCallManager e o ringback quando a chamada falha
|
||||
InCallManager.stop(); |
||||
InCallManager.stopRingback(); |
||||
}, |
||||
ended: () => { |
||||
console.log('Call ended'); |
||||
if (peerConnectionRef.current) { |
||||
peerConnectionRef.current.close(); |
||||
peerConnectionRef.current = null; |
||||
} |
||||
// Parar o InCallManager e o ringback quando a chamada termina
|
||||
InCallManager.stop(); |
||||
InCallManager.stopRingback(); |
||||
}, |
||||
confirmed: () => { |
||||
console.log('Call confirmed'); |
||||
// Parar o ringback quando a chamada é confirmada
|
||||
InCallManager.stopRingback(); |
||||
}, |
||||
}; |
||||
const options = { |
||||
eventHandlers: eventHandlers, |
||||
//Defino ao JsSIP se quero que ele capture as midias de audio e video
|
||||
mediaConstraints: { |
||||
audio: true, |
||||
video: true, |
||||
}, |
||||
rtcOfferContraints: { |
||||
offerToReceiveAudio: 1, |
||||
offerToReceiveVideo: 1, |
||||
}, |
||||
}; |
||||
console.log(calle); |
||||
const newSession = await ua.call( |
||||
`sip:${calle}@${authData.servidor}`, |
||||
options, |
||||
); |
||||
setSession(newSession); |
||||
} |
||||
} catch (error) { |
||||
console.error('Erro ao iniciar uma chamada: ', error); |
||||
} |
||||
}; |
||||
let isMuted = false; |
||||
const toggleMic = async () => { |
||||
try { |
||||
console.log('Toggling microphone...'); |
||||
if (localStream) { |
||||
const audioTrack = await localStream.getAudioTracks()[0]; |
||||
audioTrack.enabled = !audioTrack.enabled; |
||||
localMicOn ? setLocalMicOn(false) : setLocalMicOn(true); |
||||
isMuted = !isMuted; |
||||
} |
||||
} catch (err) { |
||||
console.error('Erro ao alterar microfone: ', err); |
||||
} |
||||
}; |
||||
|
||||
let isCamOn = true; |
||||
const toggleCamera = async () => { |
||||
try { |
||||
if (localStream) { |
||||
const videoTrack = await localStream.getVideoTracks()[0]; |
||||
videoTrack.enabled = !videoTrack.enabled; |
||||
localWebcamOn ? setLocalWebcamOn(false) : setLocalWebcamOn(true); |
||||
isCamOn = !isCamOn; |
||||
} |
||||
} catch (err) { |
||||
console.error('Erro inesperado ao desativar camera! ', err); |
||||
} |
||||
}; |
||||
|
||||
const toggleSpeaker = async () => { |
||||
console.log('Toggling speaker sound'); |
||||
}; |
||||
let isFrontCam = true; |
||||
const switchCamera = async () => { |
||||
try { |
||||
if (localStream) { |
||||
const videoTrack = await localStream.getVideoTracks()[0]; |
||||
videoTrack._switchCamera(); |
||||
isFrontCam = !isFrontCam; |
||||
} |
||||
} catch (err) { |
||||
console.error('Erro ao inverter camera: ', err); |
||||
} |
||||
}; |
||||
|
||||
const captureMidias = async () => { |
||||
// Obter a local track
|
||||
const senders = await peerConnectionRef.current.getSenders(); |
||||
const localStream = new MediaStream(); |
||||
senders.forEach(sender => { |
||||
if (sender.track) { |
||||
localStream.addTrack(sender.track); |
||||
} |
||||
}); |
||||
setLocalStream(localStream); |
||||
// Obter a remote track
|
||||
const receivers = await peerConnectionRef.current.getReceivers(); |
||||
const remoteStream = new MediaStream(); |
||||
receivers.forEach(receiver => { |
||||
if (receiver.track) { |
||||
remoteStream.addTrack(receiver.track); |
||||
} |
||||
}); |
||||
setRemoteStream(remoteStream); |
||||
navigation.dispatch(StackActions.replace('roomConference')); |
||||
InCallManager.setKeepScreenOn(true); |
||||
InCallManager.setSpeakerphoneOn(true); |
||||
}; |
||||
|
||||
const contextValues = useMemo( |
||||
() => ({ |
||||
session, |
||||
incommingCaller, |
||||
setCalle, |
||||
localMicOn, |
||||
setLocalMicOn, |
||||
localWebcamOn, |
||||
setLocalWebcamOn, |
||||
localStream, |
||||
remoteStream, |
||||
handleAceitarChamada, |
||||
handleEndCall, |
||||
handleIniciarChamada, |
||||
statusColor, |
||||
toggleCamera, |
||||
toggleMic, |
||||
toggleSpeaker, |
||||
switchCamera, |
||||
calle, |
||||
}), |
||||
[ |
||||
session, |
||||
incommingCaller, |
||||
setCalle, |
||||
localMicOn, |
||||
setLocalMicOn, |
||||
localWebcamOn, |
||||
setLocalWebcamOn, |
||||
localStream, |
||||
remoteStream, |
||||
handleAceitarChamada, |
||||
handleEndCall, |
||||
handleIniciarChamada, |
||||
statusColor, |
||||
calle, |
||||
], |
||||
); |
||||
return ( |
||||
<CallContext.Provider value={contextValues}> |
||||
{children} |
||||
</CallContext.Provider> |
||||
); |
||||
}; |
@ -0,0 +1,11 @@
|
||||
import React from 'react'; |
||||
import {AuthProvider} from './AuthContext'; |
||||
import {CallProvider} from './CallContext'; |
||||
|
||||
const CombinedProvider = ({children}) => ( |
||||
<AuthProvider> |
||||
<CallProvider>{children}</CallProvider> |
||||
</AuthProvider> |
||||
); |
||||
|
||||
export default CombinedProvider; |
@ -0,0 +1,145 @@
|
||||
import {View, Text} from 'react-native'; |
||||
import {RTCView} from 'react-native-webrtc'; |
||||
import styles from './styles'; |
||||
import React, {useContext, useState} from 'react'; |
||||
import {CallContext} from '../../context/CallContext'; |
||||
import IconContainer from '../../../components/IconContainer'; |
||||
import MicOn from '../../../components/MicOn'; |
||||
import MicOff from '../../../components/MicOff'; |
||||
import CallEnd from '../../../components/CallEnd'; |
||||
import VideoOn from '../../../components/VideoOn'; |
||||
import VideoOff from '../../../components/VideoOff'; |
||||
// import VivaVozIcon from '../../../components/VivaVoz';
|
||||
import CameraSwitch from '../../../components/CameraSwitch'; |
||||
import DialpadModal from '../ModalKeyPad/ModalKeyPad'; |
||||
import Icon from 'react-native-vector-icons/MaterialCommunityIcons'; |
||||
|
||||
const ConferenceScreen = () => { |
||||
const { |
||||
remoteStream, |
||||
localStream, |
||||
handleEndCall, |
||||
toggleMic, |
||||
toggleCamera, |
||||
// toggleSpeaker,
|
||||
switchCamera, |
||||
localWebcamOn, |
||||
localMicOn, |
||||
} = useContext(CallContext); |
||||
|
||||
const [isDialpadVisible, setDialpadVisible] = useState(false); |
||||
return ( |
||||
<View |
||||
style={{ |
||||
flex: 1, |
||||
backgroundColor: '#050A0E', |
||||
paddingHorizontal: 12, |
||||
paddingVertical: 12, |
||||
}}> |
||||
{remoteStream ? ( |
||||
<RTCView |
||||
mirror={true} |
||||
objectFit={'cover'} |
||||
style={{ |
||||
flex: 1, |
||||
backgroundColor: '#050A0E', |
||||
marginTop: 8, |
||||
}} |
||||
streamURL={remoteStream.toURL()} |
||||
/> |
||||
) : null} |
||||
{localStream ? ( |
||||
<RTCView |
||||
mirror={true} |
||||
objectFit={'cover'} |
||||
style={{flex: 1, backgroundColor: '#050A0E'}} |
||||
streamURL={localStream.toURL()} |
||||
/> |
||||
) : null} |
||||
<View |
||||
style={{ |
||||
marginVertical: 12, |
||||
flexDirection: 'row', |
||||
justifyContent: 'space-evenly', |
||||
}}> |
||||
<IconContainer |
||||
backgroundColor={'red'} |
||||
onPress={handleEndCall} |
||||
Icon={() => { |
||||
return <CallEnd height={26} width={26} fill="#FFF" />; |
||||
}} |
||||
/> |
||||
<IconContainer |
||||
style={{ |
||||
borderWidth: 1.5, |
||||
borderColor: '#2B3034', |
||||
}} |
||||
backgroundColor={!localMicOn ? '#fff' : 'transparent'} |
||||
onPress={toggleMic} |
||||
Icon={() => { |
||||
return localMicOn ? ( |
||||
<MicOn height={24} width={24} fill="#FFF" /> |
||||
) : ( |
||||
<MicOff height={28} width={28} fill="#1D2939" /> |
||||
); |
||||
}} |
||||
/> |
||||
<IconContainer |
||||
style={{ |
||||
borderWidth: 1.5, |
||||
borderColor: '#2B3034', |
||||
}} |
||||
backgroundColor={!localWebcamOn ? '#fff' : 'transparent'} |
||||
onPress={toggleCamera} |
||||
Icon={() => { |
||||
return localWebcamOn ? ( |
||||
<VideoOn height={24} width={24} fill="#FFF" /> |
||||
) : ( |
||||
<VideoOff height={36} width={36} fill="#1D2939" /> |
||||
); |
||||
}} |
||||
/> |
||||
|
||||
{/* <IconContainer |
||||
style={{ |
||||
borderWidth: 1.5, |
||||
borderColor: '#2B3034', |
||||
}} |
||||
onPress={toggleSpeaker} |
||||
Icon={() => { |
||||
return <VivaVozIcon width={24} height={24} fill="#FFF" />; |
||||
}} |
||||
/> */} |
||||
|
||||
<IconContainer |
||||
style={{ |
||||
borderWidth: 1.5, |
||||
borderColor: '#2B3034', |
||||
}} |
||||
backgroundColor={'transparent'} |
||||
onPress={switchCamera} |
||||
Icon={() => { |
||||
return <CameraSwitch height={24} width={24} fill="#FFF" />; |
||||
}} |
||||
/> |
||||
<IconContainer |
||||
style={{ |
||||
borderWidth: 1.5, |
||||
borderColor: '#2B3034', |
||||
}} |
||||
backgroundColor={'transparent'} |
||||
onPress={() => setDialpadVisible(true)} |
||||
Icon={() => { |
||||
return <Icon name={'dialpad'} size={30} color={'white'} />; |
||||
}} |
||||
/> |
||||
</View> |
||||
<DialpadModal |
||||
visible={isDialpadVisible} |
||||
onClose={() => setDialpadVisible(false)} |
||||
/> |
||||
</View> |
||||
); |
||||
}; |
||||
|
||||
export default ConferenceScreen; |
@ -0,0 +1,80 @@
|
||||
import {useNavigation} from '@react-navigation/native'; |
||||
import React, {memo, useContext} from 'react'; |
||||
import {View, Text, TouchableOpacity} from 'react-native'; |
||||
import {Appbar, IconButton} from 'react-native-paper'; |
||||
import {SafeAreaProvider, SafeAreaView} from 'react-native-safe-area-context'; |
||||
import styles from './styles'; |
||||
import LabeledInput from '../../../components/LabeledInput/function'; |
||||
import {AuthContext} from '../../context/AuthContext'; |
||||
|
||||
const ConfigScreen = () => { |
||||
const navigation = useNavigation(); |
||||
const {authData, handleInputChange, handleSubmit} = useContext(AuthContext); |
||||
|
||||
function handleNavigate(destiny) { |
||||
navigation.replace(destiny); |
||||
} |
||||
|
||||
return ( |
||||
<SafeAreaProvider> |
||||
<SafeAreaView style={styles.container}> |
||||
<Appbar.Header style={styles.header}> |
||||
<IconButton |
||||
icon={'arrow-left-bold-circle'} |
||||
size={30} |
||||
onPress={() => handleNavigate('home')} |
||||
/> |
||||
</Appbar.Header> |
||||
<Text style={styles.title}>Configurações</Text> |
||||
<View style={styles.configInputs}> |
||||
<LabeledInput |
||||
label="Servidor" |
||||
value={authData.servidor || ''} |
||||
onChangeText={value => handleInputChange('servidor', value)} |
||||
placeholder="Servidor" |
||||
keyboardType="number-pad" |
||||
/> |
||||
<LabeledInput |
||||
label="Porta" |
||||
value={authData.porta || ''} |
||||
onChangeText={value => handleInputChange('porta', value)} |
||||
placeholder="Porta" |
||||
keyboardType="number-pad" |
||||
/> |
||||
<LabeledInput |
||||
label="Ramal" |
||||
value={authData.ramal || ''} |
||||
onChangeText={value => handleInputChange('ramal', value)} |
||||
placeholder="Ramal" |
||||
keyboardType="number-pad" |
||||
/> |
||||
<LabeledInput |
||||
label="Username" |
||||
value={authData.username || ''} |
||||
onChangeText={value => handleInputChange('username', value)} |
||||
placeholder="Username" |
||||
/> |
||||
<LabeledInput |
||||
label="Senha" |
||||
value={authData.senha || ''} |
||||
secureTextEntry={true} |
||||
onChangeText={value => handleInputChange('senha', value)} |
||||
placeholder="Senha" |
||||
/> |
||||
</View> |
||||
<TouchableOpacity onPress={handleSubmit}> |
||||
<View style={styles.viewBn}> |
||||
<Text style={styles.buttonSend}>Conectar</Text> |
||||
<IconButton |
||||
icon={'account-arrow-right-outline'} |
||||
iconColor="rgba(255,255,255,1)" |
||||
size={28} |
||||
/> |
||||
</View> |
||||
</TouchableOpacity> |
||||
</SafeAreaView> |
||||
</SafeAreaProvider> |
||||
); |
||||
}; |
||||
|
||||
export default memo(ConfigScreen); |
@ -0,0 +1,69 @@
|
||||
import {StyleSheet} from 'react-native'; |
||||
|
||||
const styles = StyleSheet.create({ |
||||
container: { |
||||
flex: 1, |
||||
justifyContent: 'flex-start', |
||||
backgroundColor: 'rgba(9, 10, 32, 1)', |
||||
}, |
||||
header: { |
||||
width: '100%', |
||||
height: 60, |
||||
backgroundColor: 'rgba(17, 14, 38, 1)', |
||||
borderBottomLeftRadius: 8, |
||||
borderBottomRightRadius: 8, |
||||
}, |
||||
configInputs: { |
||||
marginTop: 20, |
||||
alignContent: 'center', |
||||
alignItems: 'stretch', |
||||
}, |
||||
label: { |
||||
fontSize: 12, |
||||
marginLeft: 4, |
||||
marginBottom: 1, |
||||
fontWeight: 'bold', |
||||
letterSpacing: 1, |
||||
}, |
||||
input: { |
||||
backgroundColor: 'rgba(8,20,55,0.6)', |
||||
borderRadius: 4, |
||||
paddingHorizontal: 10, |
||||
}, |
||||
buttonSend: { |
||||
color: 'rgba(255,255,255,1)', |
||||
fontSize: 16, |
||||
letterSpacing: 1, |
||||
fontWeight: 'bold', |
||||
alignSelf: 'center', |
||||
justifyContent: 'space-evenly', |
||||
}, |
||||
viewBn: { |
||||
display: 'flex', |
||||
flexDirection: 'row', |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
marginTop: 10, |
||||
backgroundColor: 'rgba(8,20,55,0.6)', |
||||
borderColor: '#5A54CE', |
||||
borderWidth: 1, |
||||
width: '46%', |
||||
alignSelf: 'center', |
||||
borderRadius: 4, |
||||
height: 40, |
||||
}, |
||||
containerLabel: { |
||||
marginHorizontal: 16, |
||||
marginVertical: 4, |
||||
}, |
||||
title: { |
||||
color: 'rgba(255,255,255,1)', |
||||
fontSize: 18, |
||||
alignSelf: 'center', |
||||
fontWeight: 'bold', |
||||
letterSpacing: 1, |
||||
marginTop: 10, |
||||
}, |
||||
}); |
||||
|
||||
export default styles; |
@ -0,0 +1,53 @@
|
||||
import React, {useContext} from 'react'; |
||||
import {View, Text, TouchableOpacity} from 'react-native'; |
||||
import * as Animatable from 'react-native-animatable'; |
||||
import styles from './styles'; |
||||
import {CallContext} from '../../context/CallContext'; |
||||
import CallAnswer from '../../../components/CallAnswer'; |
||||
import CallEnd from '../../../components/CallEnd'; |
||||
|
||||
const IncomingCallScreen = () => { |
||||
const {handleAceitarChamada, handleEndCall, incommingCaller} = |
||||
useContext(CallContext); |
||||
|
||||
const onPressAceitarChamada = () => { |
||||
handleAceitarChamada(); |
||||
}; |
||||
|
||||
const onPressEndCall = () => { |
||||
handleEndCall(); |
||||
}; |
||||
|
||||
return ( |
||||
<View style={styles.container}> |
||||
<View style={styles.centerContainer}> |
||||
<Text style={styles.callerText}> |
||||
Recebendo ligação de {incommingCaller} |
||||
</Text> |
||||
</View> |
||||
<View style={styles.buttonContainer}> |
||||
<TouchableOpacity onPress={onPressAceitarChamada}> |
||||
<Animatable.View |
||||
animation="pulse" |
||||
easing="ease-out" |
||||
iterationCount="infinite" |
||||
style={styles.callButton}> |
||||
<CallAnswer height={28} fill={'#fff'} style={styles.buttonIcon} /> |
||||
</Animatable.View> |
||||
</TouchableOpacity> |
||||
|
||||
<TouchableOpacity onPress={onPressEndCall}> |
||||
<Animatable.View |
||||
animation="pulse" |
||||
easing="ease-out" |
||||
iterationCount="infinite" |
||||
style={styles.callEndButton}> |
||||
<CallEnd width={50} height={12} style={styles.endButtonIcon} /> |
||||
</Animatable.View> |
||||
</TouchableOpacity> |
||||
</View> |
||||
</View> |
||||
); |
||||
}; |
||||
|
||||
export default IncomingCallScreen; |
@ -0,0 +1,55 @@
|
||||
import {StyleSheet} from 'react-native'; |
||||
|
||||
export default StyleSheet.create({ |
||||
container: { |
||||
flex: 1, |
||||
justifyContent: 'space-around', |
||||
backgroundColor: 'rgba(9, 10, 32, 1)', |
||||
}, |
||||
centerContainer: { |
||||
padding: 35, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
borderRadius: 14, |
||||
}, |
||||
callerText: { |
||||
fontSize: 26, |
||||
marginTop: 15, |
||||
color: '#ffff', |
||||
}, |
||||
buttonContainer: { |
||||
flexDirection: 'row', |
||||
justifyContent: 'space-evenly', |
||||
alignItems: 'center', |
||||
}, |
||||
callButton: { |
||||
backgroundColor: 'green', |
||||
borderRadius: 30, |
||||
height: 60, |
||||
aspectRatio: 1, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
position: 'relative', |
||||
}, |
||||
callEndButton: { |
||||
backgroundColor: '#FF5D5D', |
||||
borderRadius: 30, |
||||
height: 60, |
||||
aspectRatio: 1, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
position: 'relative', |
||||
}, |
||||
buttonIcon: { |
||||
position: 'absolute', |
||||
top: '50%', |
||||
left: '50%', |
||||
transform: [{translateX: -33}, {translateY: -15}], |
||||
}, |
||||
endButtonIcon: { |
||||
position: 'absolute', |
||||
top: '50%', |
||||
left: '50%', |
||||
transform: [{translateX: -25}, {translateY: -6}], |
||||
}, |
||||
}); |
@ -0,0 +1,127 @@
|
||||
import { |
||||
Keyboard, |
||||
KeyboardAvoidingView, |
||||
View, |
||||
Text, |
||||
TouchableWithoutFeedback, |
||||
TouchableOpacity, |
||||
Alert, |
||||
} from 'react-native'; |
||||
import React, {memo, useContext, useState, useEffect} from 'react'; |
||||
import Logo from '../../../components/Logo'; |
||||
import TextInputContainer from '../../../components/TextInputContainer'; |
||||
import {SafeAreaProvider, SafeAreaView} from 'react-native-safe-area-context'; |
||||
import {IconButton, MD2Colors} from 'react-native-paper'; |
||||
import Icon from 'react-native-vector-icons/FontAwesome'; |
||||
import styles from './styles'; |
||||
import Clipboard from '@react-native-clipboard/clipboard'; |
||||
import {CallContext} from '../../context/CallContext'; |
||||
import {useNavigation} from '@react-navigation/native'; |
||||
import {AuthContext} from '../../context/AuthContext'; |
||||
|
||||
const handleCopyToClipboard = text => { |
||||
Clipboard.setString(text); |
||||
Alert.alert('Ramal copiado para área de transferência!'); |
||||
}; |
||||
|
||||
const JoinScreen = () => { |
||||
const {setCalle, handleIniciarChamada, statusColor} = useContext(CallContext); |
||||
const {authData} = useContext(AuthContext); |
||||
const navigation = useNavigation(); |
||||
const [number, setNumber] = useState(''); |
||||
const [callInitiated, setCallInitiated] = useState(false); |
||||
|
||||
const handleCall = async () => { |
||||
if (!number) { |
||||
Alert.alert('Por favor, insira o ramal para realizar a ligação.'); |
||||
return; |
||||
} |
||||
|
||||
setCalle(number); |
||||
setCallInitiated(true); |
||||
}; |
||||
|
||||
function handleNavigate(destiny) { |
||||
navigation.replace(destiny); |
||||
} |
||||
|
||||
// Efeito para monitorar quando a chamada deve ser iniciada
|
||||
useEffect(() => { |
||||
if (callInitiated) { |
||||
handleIniciarChamada(); |
||||
navigation.navigate('outgoingCall'); |
||||
setCallInitiated(false); |
||||
} |
||||
}, [callInitiated]); |
||||
|
||||
return ( |
||||
<SafeAreaProvider> |
||||
<KeyboardAvoidingView |
||||
behavior={Platform.OS === 'ios' ? 'padding' : 'height'} |
||||
style={styles.container}> |
||||
<SafeAreaView style={styles.header}> |
||||
<View style={styles.viewBnConfig}> |
||||
<IconButton |
||||
style={styles.settingsButton} |
||||
icon={'account-cog'} |
||||
iconColor={MD2Colors.grey300} |
||||
size={30} |
||||
onPress={() => handleNavigate('configuracoes')} |
||||
/> |
||||
</View> |
||||
<View style={styles.logoContainer}> |
||||
<Text style={styles.subtitle}>Softphone</Text> |
||||
<Logo /> |
||||
</View> |
||||
</SafeAreaView> |
||||
<View style={styles.inner}> |
||||
<View |
||||
style={{ |
||||
display: 'flex', |
||||
flexDirection: 'row', |
||||
justifyContent: 'center', |
||||
width: '100%', |
||||
}}> |
||||
<Icon |
||||
name={'circle'} |
||||
color={statusColor} |
||||
size={20} |
||||
style={{marginHorizontal: 4}} |
||||
/> |
||||
<Text style={styles.titles}>{authData.username}</Text> |
||||
</View> |
||||
<TouchableOpacity |
||||
onPress={() => handleCopyToClipboard(authData.ramal)}> |
||||
<View style={styles.box}> |
||||
<Text style={styles.idCall}>{authData.ramal || '0000'}</Text> |
||||
</View> |
||||
</TouchableOpacity> |
||||
</View> |
||||
<TouchableWithoutFeedback onPress={Keyboard.dismiss}> |
||||
<View style={styles.inner}> |
||||
<Text style={{fontSize: 14, color: 'rgba(255,255,255,1)'}}> |
||||
Insira o ramal para ligação |
||||
</Text> |
||||
<TextInputContainer |
||||
style={styles.textInput} |
||||
value={number} |
||||
setValue={setNumber} |
||||
keyboardType={'number-pad'} |
||||
/> |
||||
<View> |
||||
<IconButton |
||||
icon={'phone'} |
||||
size={45} |
||||
onPress={handleCall} |
||||
iconColor={MD2Colors.lightGreen300} |
||||
backgroundColor={MD2Colors.green900} |
||||
/> |
||||
</View> |
||||
</View> |
||||
</TouchableWithoutFeedback> |
||||
</KeyboardAvoidingView> |
||||
</SafeAreaProvider> |
||||
); |
||||
}; |
||||
|
||||
export default memo(JoinScreen); |
@ -0,0 +1,87 @@
|
||||
import {StyleSheet} from 'react-native'; |
||||
|
||||
const styles = StyleSheet.create({ |
||||
container: { |
||||
flex: 1, |
||||
justifyContent: 'center', |
||||
padding: 12, |
||||
backgroundColor: 'rgba(9, 10, 32, 1)', |
||||
}, |
||||
viewBnConfig: { |
||||
width: '100%', |
||||
flexDirection: 'row', |
||||
justifyContent: 'flex-end', |
||||
position: 'relative', |
||||
top: 0, |
||||
}, |
||||
settingsButton: { |
||||
justifyContent: 'center', |
||||
alignSelf: 'center', |
||||
}, |
||||
logoContainer: { |
||||
alignItems: 'center', |
||||
marginBottom: 18, |
||||
}, |
||||
subtitle: { |
||||
fontSize: 16, |
||||
textAlign: 'center', |
||||
alignSelf: 'flex-start', |
||||
marginLeft: 34, |
||||
fontWeight: 'bold', |
||||
color: 'rgba(255,255,255,1)', |
||||
}, |
||||
inner: { |
||||
marginVertical: 10, |
||||
padding: 12, |
||||
backgroundColor: 'rgba(18, 20, 55, 0.3)', |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
borderRadius: 10, |
||||
}, |
||||
titles: { |
||||
fontSize: 16, |
||||
fontWeight: 'bold', |
||||
marginBottom: 4, |
||||
letterSpacing: 1, |
||||
color: 'rgba(255,255,255,1)', |
||||
}, |
||||
box: { |
||||
padding: 16, |
||||
alignItems: 'center', |
||||
marginBottom: 16, |
||||
}, |
||||
idCall: { |
||||
fontSize: 34, |
||||
fontWeight: 'bold', |
||||
color: 'rgba(255,255,255,1)', |
||||
letterSpacing: 6, |
||||
}, |
||||
buttonCall: { |
||||
backgroundColor: 'green', |
||||
borderRadius: 100, |
||||
paddingVertical: 12, |
||||
alignItems: 'center', |
||||
width: '60%', |
||||
marginTop: 16, |
||||
}, |
||||
textInput: { |
||||
borderRadius: 10, |
||||
margin: 10, |
||||
fontSize: 30, |
||||
justifyContent: 'center', |
||||
alignSelf: 'center', |
||||
fontWeight: 'bold', |
||||
height: 60, |
||||
width: '60%', |
||||
backgroundColor: 'rgba(255,255,255,0.1)', |
||||
color: 'rgba(255,255,255,1)', |
||||
}, |
||||
header: { |
||||
position: 'relative', |
||||
alignSelf: 'center', |
||||
top: -50, |
||||
height: 140, |
||||
}, |
||||
}); |
||||
|
||||
export default styles; |
@ -0,0 +1,47 @@
|
||||
import React, {useContext} from 'react'; |
||||
import {Modal, View, Text, TouchableOpacity, Alert} from 'react-native'; |
||||
import {CallContext} from '../../context/CallContext'; |
||||
import styles from './styles'; |
||||
|
||||
const DialpadModal = ({visible, onClose}) => { |
||||
const {session} = useContext(CallContext); |
||||
|
||||
const sendDTMF = tone => { |
||||
if (session) { |
||||
session.sendDTMF(tone); |
||||
console.log(`DTMF tone ${tone} sent`); |
||||
} else { |
||||
Alert.alert('Erro', 'Nenhuma sessão ativa para enviar DTMF'); |
||||
} |
||||
}; |
||||
|
||||
const renderButton = number => ( |
||||
<TouchableOpacity |
||||
key={number} |
||||
style={styles.button} |
||||
onPress={() => sendDTMF(number)}> |
||||
<Text style={styles.buttonText}>{number}</Text> |
||||
</TouchableOpacity> |
||||
); |
||||
|
||||
return ( |
||||
<Modal |
||||
animationType="slide" |
||||
transparent={true} |
||||
visible={visible} |
||||
onRequestClose={onClose}> |
||||
<View style={styles.modalContainer}> |
||||
<View style={styles.dialpad}> |
||||
{['1', '2', '3', '4', '5', '6', '7', '8', '9', '*', '0', '#'].map( |
||||
renderButton, |
||||
)} |
||||
</View> |
||||
<TouchableOpacity style={styles.closeButton} onPress={onClose}> |
||||
<Text style={styles.closeButtonText}>Fechar</Text> |
||||
</TouchableOpacity> |
||||
</View> |
||||
</Modal> |
||||
); |
||||
}; |
||||
|
||||
export default DialpadModal; |
@ -0,0 +1,47 @@
|
||||
import {StyleSheet} from 'react-native'; |
||||
|
||||
const styles = StyleSheet.create({ |
||||
modalContainer: { |
||||
flex: 1, |
||||
justifyContent: 'flex-end', |
||||
backgroundColor: 'rgba(0, 0, 0, 0.2)', |
||||
}, |
||||
dialpad: { |
||||
backgroundColor: 'rgba(0,0,0,0.9)', |
||||
padding: 25, |
||||
borderTopLeftRadius: 10, |
||||
borderTopRightRadius: 10, |
||||
alignItems: 'center', |
||||
flexDirection: 'row', |
||||
flexWrap: 'wrap', |
||||
justifyContent: 'center', |
||||
}, |
||||
button: { |
||||
width: 65, |
||||
height: 65, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
margin: 5, |
||||
borderRadius: 35, |
||||
backgroundColor: 'rgba(128, 128, 128, 0.5)', |
||||
}, |
||||
buttonText: { |
||||
color: 'white', |
||||
fontSize: 26, |
||||
fontWeight: 'bold', |
||||
}, |
||||
closeButton: { |
||||
backgroundColor: 'rgba(255,0,0,0.9)', |
||||
padding: 14, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
}, |
||||
closeButtonText: { |
||||
color: 'white', |
||||
fontSize: 18, |
||||
fontWeight: 'bold', |
||||
letterSpacing: 1, |
||||
}, |
||||
}); |
||||
|
||||
export default styles; |
@ -0,0 +1,65 @@
|
||||
import {View, Text, TouchableOpacity} from 'react-native'; |
||||
import * as Animatable from 'react-native-animatable'; |
||||
import styles from './styles'; |
||||
import React, {memo, useContext} from 'react'; |
||||
import {CallContext} from '../../context/CallContext'; |
||||
import CallEnd from '../../../components/CallEnd'; |
||||
|
||||
const OutgoingCallScreen = () => { |
||||
const {handleEndCall, calle} = useContext(CallContext); |
||||
|
||||
return ( |
||||
<View |
||||
style={{ |
||||
flex: 1, |
||||
justifyContent: 'space-around', |
||||
backgroundColor: 'rgba(9, 10, 32, 1)', |
||||
}}> |
||||
<View |
||||
style={{ |
||||
padding: 35, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
borderRadius: 14, |
||||
}}> |
||||
<Text |
||||
style={{ |
||||
fontSize: 16, |
||||
color: '#D0D4DD', |
||||
}}> |
||||
Ligando para ... |
||||
</Text> |
||||
|
||||
<Text |
||||
style={{ |
||||
fontSize: 36, |
||||
marginTop: 12, |
||||
color: '#ffff', |
||||
letterSpacing: 6, |
||||
}}> |
||||
{calle} |
||||
</Text> |
||||
</View> |
||||
<View |
||||
style={{ |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
}}> |
||||
<TouchableOpacity |
||||
onPress={handleEndCall} |
||||
style={{ |
||||
backgroundColor: '#FF5D5D', |
||||
borderRadius: 30, |
||||
height: 60, |
||||
aspectRatio: 1, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
}}> |
||||
<CallEnd width={50} height={12} /> |
||||
</TouchableOpacity> |
||||
</View> |
||||
</View> |
||||
); |
||||
}; |
||||
|
||||
export default memo(OutgoingCallScreen); |
@ -0,0 +1,8 @@
|
||||
module.exports = { |
||||
presets: ['module:metro-react-native-babel-preset'], |
||||
env: { |
||||
production: { |
||||
plugins: ['react-native-paper/babel'], |
||||
}, |
||||
}, |
||||
}; |
@ -0,0 +1,51 @@
|
||||
import React from 'react'; |
||||
import {Animated, TouchableOpacity, View, StyleSheet} from 'react-native'; |
||||
|
||||
const AnimatedButton = ({onPress, children}) => { |
||||
const animatedValue = useRef(new Animated.Value(1)).current; |
||||
|
||||
const onPressIn = () => { |
||||
Animated.timing(animatedValue, { |
||||
toValue: 0.7, |
||||
duration: 100, |
||||
useNativeDriver: true, |
||||
}).start(); |
||||
}; |
||||
|
||||
const onPressOut = () => { |
||||
Animated.timing(animatedValue, { |
||||
toValue: 1, |
||||
duration: 100, |
||||
useNativeDriver: true, |
||||
}).start(); |
||||
}; |
||||
|
||||
const animatedStyle = { |
||||
backgroundColor: '#FF5D5D', |
||||
borderRadius: 30, |
||||
opacity: animatedValue, |
||||
}; |
||||
|
||||
return ( |
||||
<TouchableOpacity |
||||
onPress={onPress} |
||||
onPressIn={onPressIn} |
||||
onPressOut={onPressOut} |
||||
style={styles.button}> |
||||
<Animated.View style={animatedStyle} /> |
||||
{children} |
||||
</TouchableOpacity> |
||||
); |
||||
}; |
||||
|
||||
const styles = StyleSheet.create({ |
||||
button: { |
||||
height: 60, |
||||
aspectRatio: 1, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
position: 'relative', |
||||
}, |
||||
}); |
||||
|
||||
export default AnimatedButton; |
@ -0,0 +1,16 @@
|
||||
import * as React from 'react'; |
||||
import Svg, {Path} from 'react-native-svg'; |
||||
|
||||
const SvgComponent = props => ( |
||||
<Svg |
||||
xmlns="http://www.w3.org/2000/svg" |
||||
width={66.667} |
||||
height={66.667} |
||||
viewBox="0 0 50 50" |
||||
{...props}> |
||||
<Path d="M6.4 6.4C4.5 8.3 3 10.6 3 11.6 3.1 21.9 28.1 46.9 38.3 47c2.3 0 8.7-6.2 8.7-8.4 0-.9-2.5-3.2-5.5-5.3-5.5-3.6-5.6-3.6-8.9-2l-3.3 1.5-6.1-6.1-6-6.2 1.6-3.2c1.5-3.2 1.5-3.3-2.1-8.8-2.1-3-4.4-5.5-5.3-5.5-.9 0-3.1 1.5-5 3.4zM25 5.7c0 .5 2.1 1.4 4.6 2.1 6.1 1.6 11 6.5 12.6 12.6 1.5 5.5 3.3 6.2 2.3.8-.9-5.1-4.1-9.9-8.4-12.7C32.3 6 25 4.2 25 5.7z" /> |
||||
<Path d="M25 12c0 .5 1.2 1 2.6 1 1.6 0 3.9 1.3 6 3.4 2.1 2.1 3.4 4.4 3.4 6 0 1.4.5 2.6 1 2.6 1.7 0 1.1-4.3-1-7.7-2-3.4-6.6-6.3-10-6.3-1.1 0-2 .4-2 1zM25 17c0 .5.6 1 1.3 1 1.6 0 5.7 4.2 5.7 5.8 0 .7.5 1.2 1 1.2 2 0 1-3.2-1.9-6.1C28.2 16 25 15 25 17z" /> |
||||
</Svg> |
||||
); |
||||
|
||||
export default SvgComponent; |
@ -0,0 +1,15 @@
|
||||
import * as React from "react" |
||||
import Svg, { Path } from "react-native-svg" |
||||
|
||||
function SvgComponent(props) { |
||||
return ( |
||||
<Svg width={22.882} height={7.844} viewBox="0 0 22.882 7.844" {...props}> |
||||
<Path |
||||
d="M11.441 1.771a15.2 15.2 0 00-4.386.637v2.749a.889.889 0 01-.534.8A11.116 11.116 0 003.98 7.595a.991.991 0 01-.667.252.969.969 0 01-.672-.261L.281 5.392a.843.843 0 010-1.257A16.829 16.829 0 0111.441 0 16.829 16.829 0 0122.6 4.134a.846.846 0 01.281.629.836.836 0 01-.281.624l-2.36 2.191a.989.989 0 01-.672.261 1 1 0 01-.667-.252 11.117 11.117 0 00-2.541-1.638.889.889 0 01-.534-.8V2.4a15.349 15.349 0 00-4.385-.629z" |
||||
fill="#fff" |
||||
/> |
||||
</Svg> |
||||
) |
||||
} |
||||
|
||||
export default SvgComponent |
@ -0,0 +1,22 @@
|
||||
import * as React from "react"; |
||||
import Svg, { Defs, Path } from "react-native-svg"; |
||||
|
||||
function CameraSwitch(props) { |
||||
return ( |
||||
<Svg viewBox="0 0 19.046 16.357" {...props}> |
||||
<Defs></Defs> |
||||
<Path |
||||
className="a" |
||||
d="M21.045 11.238a.682.682 0 00-.627-.423h-.8a7.708 7.708 0 00-.443-1.608 8.178 8.178 0 00-15.239 0 .682.682 0 101.27.493 6.815 6.815 0 0112.7 0 6.134 6.134 0 01.314 1.118h-.532a.686.686 0 00-.484 1.165l1.363 1.363.109.068h.034a.634.634 0 00.341.129.682.682 0 00.484-.2l1.365-1.362a.682.682 0 00.145-.743zm-2.256 3.033a.682.682 0 00-.879.388 6.815 6.815 0 01-12.7 0 6.134 6.134 0 01-.314-1.118h.532a.686.686 0 00.484-1.165l-1.367-1.363-.109-.068a.682.682 0 00-.825.089L2.248 12.4a.669.669 0 00.45 1.145h.8a7.708 7.708 0 00.443 1.608 8.178 8.178 0 0015.239 0 .682.682 0 00-.391-.882z" |
||||
transform="translate(-2.052 -4)" |
||||
/> |
||||
<Path |
||||
className="a" |
||||
d="M13.602 12.179a2.045 2.045 0 10-2.045 2.045 2.045 2.045 0 002.045-2.045zm-2.726 0a.682.682 0 11.682.682.682.682 0 01-.682-.682z" |
||||
transform="translate(-2.052 -4)" |
||||
/> |
||||
</Svg> |
||||
); |
||||
} |
||||
|
||||
export default CameraSwitch; |
@ -0,0 +1,21 @@
|
||||
import React from 'react'; |
||||
import {TouchableOpacity} from 'react-native'; |
||||
|
||||
const IconContainer = ({backgroundColor, onPress, Icon, style}) => { |
||||
return ( |
||||
<TouchableOpacity |
||||
onPress={onPress} |
||||
style={{ |
||||
...style, |
||||
backgroundColor: backgroundColor ? backgroundColor : 'transparent', |
||||
borderRadius: 30, |
||||
height: 60, |
||||
aspectRatio: 1, |
||||
justifyContent: 'center', |
||||
alignItems: 'center', |
||||
}}> |
||||
<Icon /> |
||||
</TouchableOpacity> |
||||
); |
||||
}; |
||||
export default IconContainer; |
@ -0,0 +1,44 @@
|
||||
import React, {useState} from 'react'; |
||||
import {View, Text, TextInput} from 'react-native'; |
||||
import styles from './styles'; |
||||
|
||||
const LabeledInput = ({ |
||||
label, |
||||
value, |
||||
onChangeText, |
||||
placeholder, |
||||
secureTextEntry, |
||||
keyboardType, |
||||
}) => { |
||||
const [isFocused, setIsFocused] = useState(false); |
||||
|
||||
const handleFocus = () => { |
||||
setIsFocused(true); |
||||
}; |
||||
|
||||
const handleBlur = () => { |
||||
setIsFocused(false); |
||||
}; |
||||
|
||||
return ( |
||||
<View style={styles.containerLabel}> |
||||
<Text style={styles.label}>{label}</Text> |
||||
<TextInput |
||||
style={[ |
||||
styles.input, |
||||
{borderBottomWidth: isFocused ? 3 : 0}, |
||||
{borderColor: isFocused ? '#5A54CE' : 'transparent'}, |
||||
]} |
||||
value={value} |
||||
onChangeText={onChangeText} |
||||
placeholder={placeholder} |
||||
secureTextEntry={secureTextEntry} |
||||
keyboardType={keyboardType} |
||||
onFocus={handleFocus} |
||||
onBlur={handleBlur} |
||||
/> |
||||
</View> |
||||
); |
||||
}; |
||||
|
||||
export default LabeledInput; |
@ -0,0 +1,23 @@
|
||||
import {StyleSheet} from 'react-native'; |
||||
const styles = StyleSheet.create({ |
||||
label: { |
||||
fontSize: 13, |
||||
marginLeft: 4, |
||||
marginBottom: 1, |
||||
fontWeight: 'bold', |
||||
letterSpacing: 1, |
||||
color: 'rgba(255,255,255,1)', |
||||
}, |
||||
input: { |
||||
backgroundColor: 'rgba(8,20,55,0.6)', |
||||
borderRadius: 4, |
||||
paddingHorizontal: 10, |
||||
color: 'rgba(255,255,255,0.8)', |
||||
}, |
||||
containerLabel: { |
||||
marginHorizontal: 16, |
||||
marginVertical: 4, |
||||
}, |
||||
}); |
||||
|
||||
export default styles; |
@ -0,0 +1,27 @@
|
||||
import * as React from "react"; |
||||
import Svg, { G, Path, Defs, ClipPath } from "react-native-svg"; |
||||
|
||||
function Leave(props) { |
||||
return ( |
||||
<Svg |
||||
width={24} |
||||
height={24} |
||||
viewBox="0 0 24 24" |
||||
fill="none" |
||||
xmlns="http://www.w3.org/2000/svg" |
||||
{...props} |
||||
> |
||||
<G clipPath="url(#clip0_226_104)" fill="#fff"> |
||||
<Path d="M3 0h11c1.7 0 3 1.3 3 3v6H8c-1.7 0-3 1.3-3 3s1.3 3 3 3h9v6c0 1.7-1.3 3-3 3H3c-1.7 0-3-1.3-3-3V3c0-1.7 1.4-3 3-3z" /> |
||||
<Path d="M20.6 13H8c-.6 0-1-.4-1-1s.4-1 1-1h12.6l-1.3-1.3c-.4-.4-.4-1 0-1.4.4-.4 1-.4 1.4 0l3 3c.4.4.4 1 0 1.4l-3 3c-.4.4-1 .4-1.4 0-.4-.4-.4-1 0-1.4l1.3-1.3z" /> |
||||
</G> |
||||
<Defs> |
||||
<ClipPath id="clip0_226_104"> |
||||
<Path fill="#fff" d="M0 0H24V24H0z" /> |
||||
</ClipPath> |
||||
</Defs> |
||||
</Svg> |
||||
); |
||||
} |
||||
|
||||
export default Leave; |
@ -0,0 +1,18 @@
|
||||
import {View, Image} from 'react-native'; |
||||
import LogoSvg from '../asset/src/logo_simples_ip.svg'; |
||||
import React from 'react'; |
||||
|
||||
const Logo = () => { |
||||
return ( |
||||
<View |
||||
style={{ |
||||
alignItems: 'center', |
||||
justifyContent: 'center', |
||||
width: '100%', |
||||
}}> |
||||
<LogoSvg width={'100%'} height={85} /> |
||||
</View> |
||||
); |
||||
}; |
||||
|
||||
export default Logo; |
@ -0,0 +1,16 @@
|
||||
import * as React from 'react'; |
||||
import Svg, {Path} from 'react-native-svg'; |
||||
|
||||
function MicOff(props) { |
||||
return ( |
||||
<Svg viewBox="0 0 12.691 12.691" {...props}> |
||||
<Path d="M0 0h12.691v12.691H0zm0 0h12.691v12.691H0z" fill="none" /> |
||||
<Path |
||||
d="M10.062 5.819h-.9a2.607 2.607 0 01-.231 1.087l.654.652a3.431 3.431 0 00.477-1.739zm-2.131.087c0-.029.008-.058.008-.087V2.637a1.593 1.593 0 00-3.185 0v.1zm-5.686-4.33l-.677.673 3.19 3.191v.382a1.589 1.589 0 001.587 1.591 1.638 1.638 0 00.345-.04l.881.88a2.928 2.928 0 01-1.226.273 2.753 2.753 0 01-2.813-2.704h-.9a3.7 3.7 0 003.185 3.564v1.737h1.062V9.384a3.765 3.765 0 001.348-.48l2.222 2.22.677-.674z" |
||||
fill={props.fill} |
||||
/> |
||||
</Svg> |
||||
); |
||||
} |
||||
|
||||
export default MicOff; |
@ -0,0 +1,32 @@
|
||||
import * as React from 'react'; |
||||
import Svg, {Defs, ClipPath, Path, G} from 'react-native-svg'; |
||||
|
||||
function MicOn(props) { |
||||
return ( |
||||
<Svg fill="#FFF" viewBox="0 0 15.238 16" {...props}> |
||||
<Defs> |
||||
<ClipPath id="a"> |
||||
<Path |
||||
className="a" |
||||
transform="translate(.235 .255)" |
||||
d="M0 0H15.238V16H0z" |
||||
/> |
||||
</ClipPath> |
||||
</Defs> |
||||
<G clipPath="url(#a)"> |
||||
<Path |
||||
className="a" |
||||
d="M6.765 8.909a2.225 2.225 0 002.229-2.224l.007-4.45a2.236 2.236 0 00-4.472 0v4.448a2.232 2.232 0 002.236 2.226zm3.95-2.224a3.856 3.856 0 01-3.95 3.781 3.856 3.856 0 01-3.95-3.781H1.548a5.182 5.182 0 004.472 4.982v2.431h1.491v-2.431a5.182 5.182 0 004.472-4.982z" |
||||
transform="translate(-.235 -.255) translate(1.174 .899)" |
||||
/> |
||||
<Path |
||||
d="M0 .567h13.531v13.531H0z" |
||||
transform="translate(-.235 -.255) translate(1.174 .899)" |
||||
fill="none" |
||||
/> |
||||
</G> |
||||
</Svg> |
||||
); |
||||
} |
||||
|
||||
export default MicOn; |
@ -0,0 +1,20 @@
|
||||
import React from 'react'; |
||||
import {View, TextInput} from 'react-native'; |
||||
const TextInputContainer = ({value, setValue, keyboardType, style}) => { |
||||
return ( |
||||
<View style={{width: '100%'}}> |
||||
<TextInput |
||||
style={style} |
||||
multiline={true} |
||||
numberOfLines={1} |
||||
cursorColor={'#EAEAEA'} |
||||
onChangeText={setValue} |
||||
value={value} |
||||
keyboardType={keyboardType} |
||||
textAlign="center" |
||||
/> |
||||
</View> |
||||
); |
||||
}; |
||||
|
||||
export default TextInputContainer; |
@ -0,0 +1,24 @@
|
||||
import * as React from "react"; |
||||
import Svg, { Defs, ClipPath, Path, G } from "react-native-svg"; |
||||
|
||||
function VideoOff(props) { |
||||
return ( |
||||
<Svg viewBox="0 0 31 30" {...props}> |
||||
<Defs> |
||||
<ClipPath id="a"> |
||||
<Path d="M0 0H31V30H0z" /> |
||||
</ClipPath> |
||||
</Defs> |
||||
<G clipPath="url(#a)"> |
||||
<Path |
||||
d="M21.5 16.9a1.05 1.05 0 00.5-.9V8a1.193 1.193 0 00-.5-.9.908.908 0 00-1 0L17 8.9A3.058 3.058 0 0014 6h-3.7l11 11c0-.1.1-.1.2-.1zm.2 3.4l-4.8-4.8L7.4 6 3.7 2.3a.967.967 0 00-1.4 0 .967.967 0 000 1.4L4.6 6A3.019 3.019 0 002 9v6a2.946 2.946 0 003 3h9a2.64 2.64 0 001.9-.7l4.4 4.4a.99.99 0 101.4-1.4z" |
||||
transform="translate(-47 -52) translate(50 55)" |
||||
fill={props.fill} |
||||
data-name="Group 2115" |
||||
/> |
||||
</G> |
||||
</Svg> |
||||
); |
||||
} |
||||
|
||||
export default VideoOff; |
@ -0,0 +1,15 @@
|
||||
import * as React from "react"; |
||||
import Svg, { Path } from "react-native-svg"; |
||||
|
||||
function VideoOn(props) { |
||||
return ( |
||||
<Svg viewBox="0 0 16 9.6" {...props}> |
||||
<Path |
||||
d="M15.6.88a.727.727 0 00-.8 0L12 2.32A2.446 2.446 0 009.6 0H2.4A2.357 2.357 0 000 2.4v4.8a2.357 2.357 0 002.4 2.4h7.2A2.446 2.446 0 0012 7.28l2.88 1.44a.843.843 0 001.04-.32A.721.721 0 0016 8V1.6a.955.955 0 00-.4-.72z" |
||||
fill={props.fill} |
||||
/> |
||||
</Svg> |
||||
); |
||||
} |
||||
|
||||
export default VideoOn; |
@ -0,0 +1,18 @@
|
||||
import * as React from "react"; |
||||
import Svg, { Path } from "react-native-svg"; |
||||
|
||||
function VivaVozIcon(props) { |
||||
return ( |
||||
<Svg width={24} height={24} viewBox="0 0 640 512" fill="none" {...props}> |
||||
<Path |
||||
d="M12 0c-1.654 0-3 1.346-3 3v3.76c-.727.476-1.214 1.283-1.306 2.202l-.008.171v1.117c0 2.12-1.71 3.84-3.83 3.84A3.83 3.83 0 012 13.999v-3.767a5.94 5.94 0 01-.007-.255c0-3.285 2.677-5.962 5.962-5.993a6.062 6.062 0 013.992 1.531l1.454-1.455c-.801-.79-1.889-1.279-3.091-1.279zM5 13.986v-3.987A1 1 0 016 8.998h2v7.98h-.007c-.556 0-.993-.447-.993-.993a.992.992 0 01.992-.999h.015v-1zm10 1v1h.008c.55 0 .992.448.992.998s-.442.992-.992.992H12v-7.987h2a1 1 0 011 1.007v3.987z" |
||||
fill={props.fill || "#000"} |
||||
/> |
||||
<Path |
||||
d="M533.6 32.5C598.5 85.2 640 165.8 640 256s-41.5 170.7-106.4 223.5c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C557.5 398.2 592 331.2 592 256s-34.5-142.2-88.7-186.3c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5zM473.1 107c43.2 35.2 70.9 88.9 70.9 149s-27.7 113.8-70.9 149c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C475.3 341.3 496 301.1 496 256s-20.7-85.3-53.2-111.8c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5zm-60.5 74.5C434.1 199.1 448 225.9 448 256s-13.9 56.9-35.4 74.5c-10.3 8.4-25.4 6.8-33.8-3.5s-6.8-25.4 3.5-33.8C393.1 284.4 400 271 400 256s-6.9-28.4-17.7-37.3c-10.3-8.4-11.8-23.5-3.5-33.8s23.5-11.8 33.8-3.5zM301.1 34.8C312.6 40 320 51.4 320 64V448c0 12.6-7.4 24-18.9 29.2s-25 3.1-34.4-5.3L131.8 352H64c-35.3 0-64-28.7-64-64V224c0-35.3 28.7-64 64-64h67.8L266.7 40.1c9.4-8.4 22.9-10.4 34.4-5.3z" fill={props.fill || "#000"} |
||||
/> |
||||
</Svg> |
||||
); |
||||
} |
||||
|
||||
export default VivaVozIcon; |
@ -0,0 +1,22 @@
|
||||
/** |
||||
* @format |
||||
*/ |
||||
import 'react-native-gesture-handler'; |
||||
import {AppRegistry} from 'react-native'; |
||||
import App from './App'; |
||||
import {name as appName} from './app.json'; |
||||
import {registerGlobals} from 'react-native-webrtc'; |
||||
import {PaperProvider} from 'react-native-paper'; |
||||
import React from 'react'; |
||||
|
||||
registerGlobals(); |
||||
|
||||
export default function Main() { |
||||
return ( |
||||
<PaperProvider> |
||||
<App /> |
||||
</PaperProvider> |
||||
); |
||||
} |
||||
|
||||
AppRegistry.registerComponent(appName, () => Main); |
@ -0,0 +1,11 @@
|
||||
# This `.xcode.env` file is versioned and is used to source the environment |
||||
# used when running script phases inside Xcode. |
||||
# To customize your local environment, you can create an `.xcode.env.local` |
||||
# file that is not versioned. |
||||
|
||||
# NODE_BINARY variable contains the PATH to the node executable. |
||||
# |
||||
# Customize the NODE_BINARY variable here. |
||||
# For example, to use nvm with brew, add the following line |
||||
# . "$(brew --prefix nvm)/nvm.sh" --no-use |
||||
export NODE_BINARY=$(command -v node) |
@ -0,0 +1,55 @@
|
||||
# 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! |
||||
|
||||
# If you are using a `react-native-flipper` your iOS build will fail when `NO_FLIPPER=1` is set. |
||||
# because `react-native-flipper` depends on (FlipperKit,...) that will be excluded |
||||
# |
||||
# To fix this you can also exclude `react-native-flipper` using a `react-native.config.js` |
||||
# ```js |
||||
# module.exports = { |
||||
# dependencies: { |
||||
# ...(process.env.NO_FLIPPER ? { 'react-native-flipper': { platforms: { ios: null } } } : {}), |
||||
# ``` |
||||
flipper_config = ENV['NO_FLIPPER'] == "1" ? FlipperConfiguration.disabled : FlipperConfiguration.enabled |
||||
|
||||
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 'sip' do |
||||
config = use_native_modules! |
||||
|
||||
use_react_native!( |
||||
:path => config[:reactNativePath], |
||||
# Enables Flipper. |
||||
# |
||||
# Note that if you have use_frameworks! enabled, Flipper will not work and |
||||
# you should disable the next line. |
||||
:flipper_configuration => flipper_config, |
||||
# An absolute path to your application root. |
||||
:app_path => "#{Pod::Config.instance.installation_root}/.." |
||||
) |
||||
|
||||
target 'sipTests' do |
||||
inherit! :complete |
||||
# Pods for testing |
||||
end |
||||
|
||||
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 |
||||
) |
||||
end |
||||
end |
@ -0,0 +1,684 @@
|
||||
// !$*UTF8*$! |
||||
{ |
||||
archiveVersion = 1; |
||||
classes = { |
||||
}; |
||||
objectVersion = 54; |
||||
objects = { |
||||
|
||||
/* Begin PBXBuildFile section */ |
||||
00E356F31AD99517003FC87E /* sipTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* sipTests.m */; }; |
||||
0C80B921A6F3F58F76C31292 /* libPods-sip.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 5DCACB8F33CDC322A6C60F78 /* libPods-sip.a */; }; |
||||
13B07FBC1A68108700A75B9A /* AppDelegate.mm in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.mm */; }; |
||||
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; }; |
||||
13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; }; |
||||
7699B88040F8A987B510C191 /* libPods-sip-sipTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 19F6CBCC0A4E27FBF8BF4A61 /* libPods-sip-sipTests.a */; }; |
||||
81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */; }; |
||||
/* End PBXBuildFile section */ |
||||
|
||||
/* Begin PBXContainerItemProxy section */ |
||||
00E356F41AD99517003FC87E /* PBXContainerItemProxy */ = { |
||||
isa = PBXContainerItemProxy; |
||||
containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */; |
||||
proxyType = 1; |
||||
remoteGlobalIDString = 13B07F861A680F5B00A75B9A; |
||||
remoteInfo = sip; |
||||
}; |
||||
/* End PBXContainerItemProxy section */ |
||||
|
||||
/* Begin PBXFileReference section */ |
||||
00E356EE1AD99517003FC87E /* sipTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = sipTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; |
||||
00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; }; |
||||
00E356F21AD99517003FC87E /* sipTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = sipTests.m; sourceTree = "<group>"; }; |
||||
13B07F961A680F5B00A75B9A /* sip.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = sip.app; sourceTree = BUILT_PRODUCTS_DIR; }; |
||||
13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = sip/AppDelegate.h; sourceTree = "<group>"; }; |
||||
13B07FB01A68108700A75B9A /* AppDelegate.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = AppDelegate.mm; path = sip/AppDelegate.mm; sourceTree = "<group>"; }; |
||||
13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = sip/Images.xcassets; sourceTree = "<group>"; }; |
||||
13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = sip/Info.plist; sourceTree = "<group>"; }; |
||||
13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = sip/main.m; sourceTree = "<group>"; }; |
||||
19F6CBCC0A4E27FBF8BF4A61 /* libPods-sip-sipTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-sip-sipTests.a"; sourceTree = BUILT_PRODUCTS_DIR; }; |
||||
3B4392A12AC88292D35C810B /* Pods-sip.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-sip.debug.xcconfig"; path = "Target Support Files/Pods-sip/Pods-sip.debug.xcconfig"; sourceTree = "<group>"; }; |
||||
5709B34CF0A7D63546082F79 /* Pods-sip.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-sip.release.xcconfig"; path = "Target Support Files/Pods-sip/Pods-sip.release.xcconfig"; sourceTree = "<group>"; }; |
||||
5B7EB9410499542E8C5724F5 /* Pods-sip-sipTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-sip-sipTests.debug.xcconfig"; path = "Target Support Files/Pods-sip-sipTests/Pods-sip-sipTests.debug.xcconfig"; sourceTree = "<group>"; }; |
||||
5DCACB8F33CDC322A6C60F78 /* libPods-sip.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-sip.a"; sourceTree = BUILT_PRODUCTS_DIR; }; |
||||
81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = LaunchScreen.storyboard; path = sip/LaunchScreen.storyboard; sourceTree = "<group>"; }; |
||||
89C6BE57DB24E9ADA2F236DE /* Pods-sip-sipTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-sip-sipTests.release.xcconfig"; path = "Target Support Files/Pods-sip-sipTests/Pods-sip-sipTests.release.xcconfig"; sourceTree = "<group>"; }; |
||||
ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; }; |
||||
/* End PBXFileReference section */ |
||||
|
||||
/* Begin PBXFrameworksBuildPhase section */ |
||||
00E356EB1AD99517003FC87E /* Frameworks */ = { |
||||
isa = PBXFrameworksBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
7699B88040F8A987B510C191 /* libPods-sip-sipTests.a in Frameworks */, |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
}; |
||||
13B07F8C1A680F5B00A75B9A /* Frameworks */ = { |
||||
isa = PBXFrameworksBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
0C80B921A6F3F58F76C31292 /* libPods-sip.a in Frameworks */, |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
}; |
||||
/* End PBXFrameworksBuildPhase section */ |
||||
|
||||
/* Begin PBXGroup section */ |
||||
00E356EF1AD99517003FC87E /* sipTests */ = { |
||||
isa = PBXGroup; |
||||
children = ( |
||||
00E356F21AD99517003FC87E /* sipTests.m */, |
||||
00E356F01AD99517003FC87E /* Supporting Files */, |
||||
); |
||||
path = sipTests; |
||||
sourceTree = "<group>"; |
||||
}; |
||||
00E356F01AD99517003FC87E /* Supporting Files */ = { |
||||
isa = PBXGroup; |
||||
children = ( |
||||
00E356F11AD99517003FC87E /* Info.plist */, |
||||
); |
||||
name = "Supporting Files"; |
||||
sourceTree = "<group>"; |
||||
}; |
||||
13B07FAE1A68108700A75B9A /* sip */ = { |
||||
isa = PBXGroup; |
||||
children = ( |
||||
13B07FAF1A68108700A75B9A /* AppDelegate.h */, |
||||
13B07FB01A68108700A75B9A /* AppDelegate.mm */, |
||||
13B07FB51A68108700A75B9A /* Images.xcassets */, |
||||
13B07FB61A68108700A75B9A /* Info.plist */, |
||||
81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */, |
||||
13B07FB71A68108700A75B9A /* main.m */, |
||||
); |
||||
name = sip; |
||||
sourceTree = "<group>"; |
||||
}; |
||||
2D16E6871FA4F8E400B85C8A /* Frameworks */ = { |
||||
isa = PBXGroup; |
||||
children = ( |
||||
ED297162215061F000B7C4FE /* JavaScriptCore.framework */, |
||||
5DCACB8F33CDC322A6C60F78 /* libPods-sip.a */, |
||||
19F6CBCC0A4E27FBF8BF4A61 /* libPods-sip-sipTests.a */, |
||||
); |
||||
name = Frameworks; |
||||
sourceTree = "<group>"; |
||||
}; |
||||
832341AE1AAA6A7D00B99B32 /* Libraries */ = { |
||||
isa = PBXGroup; |
||||
children = ( |
||||
); |
||||
name = Libraries; |
||||
sourceTree = "<group>"; |
||||
}; |
||||
83CBB9F61A601CBA00E9B192 = { |
||||
isa = PBXGroup; |
||||
children = ( |
||||
13B07FAE1A68108700A75B9A /* sip */, |
||||
832341AE1AAA6A7D00B99B32 /* Libraries */, |
||||
00E356EF1AD99517003FC87E /* sipTests */, |
||||
83CBBA001A601CBA00E9B192 /* Products */, |
||||
2D16E6871FA4F8E400B85C8A /* Frameworks */, |
||||
BBD78D7AC51CEA395F1C20DB /* Pods */, |
||||
); |
||||
indentWidth = 2; |
||||
sourceTree = "<group>"; |
||||
tabWidth = 2; |
||||
usesTabs = 0; |
||||
}; |
||||
83CBBA001A601CBA00E9B192 /* Products */ = { |
||||
isa = PBXGroup; |
||||
children = ( |
||||
13B07F961A680F5B00A75B9A /* sip.app */, |
||||
00E356EE1AD99517003FC87E /* sipTests.xctest */, |
||||
); |
||||
name = Products; |
||||
sourceTree = "<group>"; |
||||
}; |
||||
BBD78D7AC51CEA395F1C20DB /* Pods */ = { |
||||
isa = PBXGroup; |
||||
children = ( |
||||
3B4392A12AC88292D35C810B /* Pods-sip.debug.xcconfig */, |
||||
5709B34CF0A7D63546082F79 /* Pods-sip.release.xcconfig */, |
||||
5B7EB9410499542E8C5724F5 /* Pods-sip-sipTests.debug.xcconfig */, |
||||
89C6BE57DB24E9ADA2F236DE /* Pods-sip-sipTests.release.xcconfig */, |
||||
); |
||||
path = Pods; |
||||
sourceTree = "<group>"; |
||||
}; |
||||
/* End PBXGroup section */ |
||||
|
||||
/* Begin PBXNativeTarget section */ |
||||
00E356ED1AD99517003FC87E /* sipTests */ = { |
||||
isa = PBXNativeTarget; |
||||
buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "sipTests" */; |
||||
buildPhases = ( |
||||
A55EABD7B0C7F3A422A6CC61 /* [CP] Check Pods Manifest.lock */, |
||||
00E356EA1AD99517003FC87E /* Sources */, |
||||
00E356EB1AD99517003FC87E /* Frameworks */, |
||||
00E356EC1AD99517003FC87E /* Resources */, |
||||
C59DA0FBD6956966B86A3779 /* [CP] Embed Pods Frameworks */, |
||||
F6A41C54EA430FDDC6A6ED99 /* [CP] Copy Pods Resources */, |
||||
); |
||||
buildRules = ( |
||||
); |
||||
dependencies = ( |
||||
00E356F51AD99517003FC87E /* PBXTargetDependency */, |
||||
); |
||||
name = sipTests; |
||||
productName = sipTests; |
||||
productReference = 00E356EE1AD99517003FC87E /* sipTests.xctest */; |
||||
productType = "com.apple.product-type.bundle.unit-test"; |
||||
}; |
||||
13B07F861A680F5B00A75B9A /* sip */ = { |
||||
isa = PBXNativeTarget; |
||||
buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "sip" */; |
||||
buildPhases = ( |
||||
C38B50BA6285516D6DCD4F65 /* [CP] Check Pods Manifest.lock */, |
||||
13B07F871A680F5B00A75B9A /* Sources */, |
||||
13B07F8C1A680F5B00A75B9A /* Frameworks */, |
||||
13B07F8E1A680F5B00A75B9A /* Resources */, |
||||
00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */, |
||||
00EEFC60759A1932668264C0 /* [CP] Embed Pods Frameworks */, |
||||
E235C05ADACE081382539298 /* [CP] Copy Pods Resources */, |
||||
); |
||||
buildRules = ( |
||||
); |
||||
dependencies = ( |
||||
); |
||||
name = sip; |
||||
productName = sip; |
||||
productReference = 13B07F961A680F5B00A75B9A /* sip.app */; |
||||
productType = "com.apple.product-type.application"; |
||||
}; |
||||
/* End PBXNativeTarget section */ |
||||
|
||||
/* Begin PBXProject section */ |
||||
83CBB9F71A601CBA00E9B192 /* Project object */ = { |
||||
isa = PBXProject; |
||||
attributes = { |
||||
LastUpgradeCheck = 1210; |
||||
TargetAttributes = { |
||||
00E356ED1AD99517003FC87E = { |
||||
CreatedOnToolsVersion = 6.2; |
||||
TestTargetID = 13B07F861A680F5B00A75B9A; |
||||
}; |
||||
13B07F861A680F5B00A75B9A = { |
||||
LastSwiftMigration = 1120; |
||||
}; |
||||
}; |
||||
}; |
||||
buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "sip" */; |
||||
compatibilityVersion = "Xcode 12.0"; |
||||
developmentRegion = en; |
||||
hasScannedForEncodings = 0; |
||||
knownRegions = ( |
||||
en, |
||||
Base, |
||||
); |
||||
mainGroup = 83CBB9F61A601CBA00E9B192; |
||||
productRefGroup = 83CBBA001A601CBA00E9B192 /* Products */; |
||||
projectDirPath = ""; |
||||
projectRoot = ""; |
||||
targets = ( |
||||
13B07F861A680F5B00A75B9A /* sip */, |
||||
00E356ED1AD99517003FC87E /* sipTests */, |
||||
); |
||||
}; |
||||
/* End PBXProject section */ |
||||
|
||||
/* Begin PBXResourcesBuildPhase section */ |
||||
00E356EC1AD99517003FC87E /* Resources */ = { |
||||
isa = PBXResourcesBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
}; |
||||
13B07F8E1A680F5B00A75B9A /* Resources */ = { |
||||
isa = PBXResourcesBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */, |
||||
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */, |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
}; |
||||
/* End PBXResourcesBuildPhase section */ |
||||
|
||||
/* Begin PBXShellScriptBuildPhase section */ |
||||
00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */ = { |
||||
isa = PBXShellScriptBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
); |
||||
inputPaths = ( |
||||
"$(SRCROOT)/.xcode.env.local", |
||||
"$(SRCROOT)/.xcode.env", |
||||
); |
||||
name = "Bundle React Native code and images"; |
||||
outputPaths = ( |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
shellPath = /bin/sh; |
||||
shellScript = "set -e\n\nWITH_ENVIRONMENT=\"../node_modules/react-native/scripts/xcode/with-environment.sh\"\nREACT_NATIVE_XCODE=\"../node_modules/react-native/scripts/react-native-xcode.sh\"\n\n/bin/sh -c \"$WITH_ENVIRONMENT $REACT_NATIVE_XCODE\"\n"; |
||||
}; |
||||
00EEFC60759A1932668264C0 /* [CP] Embed Pods Frameworks */ = { |
||||
isa = PBXShellScriptBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
); |
||||
inputFileListPaths = ( |
||||
"${PODS_ROOT}/Target Support Files/Pods-sip/Pods-sip-frameworks-${CONFIGURATION}-input-files.xcfilelist", |
||||
); |
||||
name = "[CP] Embed Pods Frameworks"; |
||||
outputFileListPaths = ( |
||||
"${PODS_ROOT}/Target Support Files/Pods-sip/Pods-sip-frameworks-${CONFIGURATION}-output-files.xcfilelist", |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
shellPath = /bin/sh; |
||||
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-sip/Pods-sip-frameworks.sh\"\n"; |
||||
showEnvVarsInLog = 0; |
||||
}; |
||||
A55EABD7B0C7F3A422A6CC61 /* [CP] Check Pods Manifest.lock */ = { |
||||
isa = PBXShellScriptBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
); |
||||
inputFileListPaths = ( |
||||
); |
||||
inputPaths = ( |
||||
"${PODS_PODFILE_DIR_PATH}/Podfile.lock", |
||||
"${PODS_ROOT}/Manifest.lock", |
||||
); |
||||
name = "[CP] Check Pods Manifest.lock"; |
||||
outputFileListPaths = ( |
||||
); |
||||
outputPaths = ( |
||||
"$(DERIVED_FILE_DIR)/Pods-sip-sipTests-checkManifestLockResult.txt", |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
shellPath = /bin/sh; |
||||
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n"; |
||||
showEnvVarsInLog = 0; |
||||
}; |
||||
C38B50BA6285516D6DCD4F65 /* [CP] Check Pods Manifest.lock */ = { |
||||
isa = PBXShellScriptBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
); |
||||
inputFileListPaths = ( |
||||
); |
||||
inputPaths = ( |
||||
"${PODS_PODFILE_DIR_PATH}/Podfile.lock", |
||||
"${PODS_ROOT}/Manifest.lock", |
||||
); |
||||
name = "[CP] Check Pods Manifest.lock"; |
||||
outputFileListPaths = ( |
||||
); |
||||
outputPaths = ( |
||||
"$(DERIVED_FILE_DIR)/Pods-sip-checkManifestLockResult.txt", |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
shellPath = /bin/sh; |
||||
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n"; |
||||
showEnvVarsInLog = 0; |
||||
}; |
||||
C59DA0FBD6956966B86A3779 /* [CP] Embed Pods Frameworks */ = { |
||||
isa = PBXShellScriptBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
); |
||||
inputFileListPaths = ( |
||||
"${PODS_ROOT}/Target Support Files/Pods-sip-sipTests/Pods-sip-sipTests-frameworks-${CONFIGURATION}-input-files.xcfilelist", |
||||
); |
||||
name = "[CP] Embed Pods Frameworks"; |
||||
outputFileListPaths = ( |
||||
"${PODS_ROOT}/Target Support Files/Pods-sip-sipTests/Pods-sip-sipTests-frameworks-${CONFIGURATION}-output-files.xcfilelist", |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
shellPath = /bin/sh; |
||||
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-sip-sipTests/Pods-sip-sipTests-frameworks.sh\"\n"; |
||||
showEnvVarsInLog = 0; |
||||
}; |
||||
E235C05ADACE081382539298 /* [CP] Copy Pods Resources */ = { |
||||
isa = PBXShellScriptBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
); |
||||
inputFileListPaths = ( |
||||
"${PODS_ROOT}/Target Support Files/Pods-sip/Pods-sip-resources-${CONFIGURATION}-input-files.xcfilelist", |
||||
); |
||||
name = "[CP] Copy Pods Resources"; |
||||
outputFileListPaths = ( |
||||
"${PODS_ROOT}/Target Support Files/Pods-sip/Pods-sip-resources-${CONFIGURATION}-output-files.xcfilelist", |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
shellPath = /bin/sh; |
||||
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-sip/Pods-sip-resources.sh\"\n"; |
||||
showEnvVarsInLog = 0; |
||||
}; |
||||
F6A41C54EA430FDDC6A6ED99 /* [CP] Copy Pods Resources */ = { |
||||
isa = PBXShellScriptBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
); |
||||
inputFileListPaths = ( |
||||
"${PODS_ROOT}/Target Support Files/Pods-sip-sipTests/Pods-sip-sipTests-resources-${CONFIGURATION}-input-files.xcfilelist", |
||||
); |
||||
name = "[CP] Copy Pods Resources"; |
||||
outputFileListPaths = ( |
||||
"${PODS_ROOT}/Target Support Files/Pods-sip-sipTests/Pods-sip-sipTests-resources-${CONFIGURATION}-output-files.xcfilelist", |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
shellPath = /bin/sh; |
||||
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-sip-sipTests/Pods-sip-sipTests-resources.sh\"\n"; |
||||
showEnvVarsInLog = 0; |
||||
}; |
||||
/* End PBXShellScriptBuildPhase section */ |
||||
|
||||
/* Begin PBXSourcesBuildPhase section */ |
||||
00E356EA1AD99517003FC87E /* Sources */ = { |
||||
isa = PBXSourcesBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
00E356F31AD99517003FC87E /* sipTests.m in Sources */, |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
}; |
||||
13B07F871A680F5B00A75B9A /* Sources */ = { |
||||
isa = PBXSourcesBuildPhase; |
||||
buildActionMask = 2147483647; |
||||
files = ( |
||||
13B07FBC1A68108700A75B9A /* AppDelegate.mm in Sources */, |
||||
13B07FC11A68108700A75B9A /* main.m in Sources */, |
||||
); |
||||
runOnlyForDeploymentPostprocessing = 0; |
||||
}; |
||||
/* End PBXSourcesBuildPhase section */ |
||||
|
||||
/* Begin PBXTargetDependency section */ |
||||
00E356F51AD99517003FC87E /* PBXTargetDependency */ = { |
||||
isa = PBXTargetDependency; |
||||
target = 13B07F861A680F5B00A75B9A /* sip */; |
||||
targetProxy = 00E356F41AD99517003FC87E /* PBXContainerItemProxy */; |
||||
}; |
||||
/* End PBXTargetDependency section */ |
||||
|
||||
/* Begin XCBuildConfiguration section */ |
||||
00E356F61AD99517003FC87E /* Debug */ = { |
||||
isa = XCBuildConfiguration; |
||||
baseConfigurationReference = 5B7EB9410499542E8C5724F5 /* Pods-sip-sipTests.debug.xcconfig */; |
||||
buildSettings = { |
||||
BUNDLE_LOADER = "$(TEST_HOST)"; |
||||
GCC_PREPROCESSOR_DEFINITIONS = ( |
||||
"DEBUG=1", |
||||
"$(inherited)", |
||||
); |
||||
INFOPLIST_FILE = sipTests/Info.plist; |
||||
IPHONEOS_DEPLOYMENT_TARGET = 13.4; |
||||
LD_RUNPATH_SEARCH_PATHS = ( |
||||
"$(inherited)", |
||||
"@executable_path/Frameworks", |
||||
"@loader_path/Frameworks", |
||||
); |
||||
OTHER_LDFLAGS = ( |
||||
"-ObjC", |
||||
"-lc++", |
||||
"$(inherited)", |
||||
); |
||||
PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; |
||||
PRODUCT_NAME = "$(TARGET_NAME)"; |
||||
TEST_HOST = "$(BUILT_PRODUCTS_DIR)/sip.app/sip"; |
||||
}; |
||||
name = Debug; |
||||
}; |
||||
00E356F71AD99517003FC87E /* Release */ = { |
||||
isa = XCBuildConfiguration; |
||||
baseConfigurationReference = 89C6BE57DB24E9ADA2F236DE /* Pods-sip-sipTests.release.xcconfig */; |
||||
buildSettings = { |
||||
BUNDLE_LOADER = "$(TEST_HOST)"; |
||||
COPY_PHASE_STRIP = NO; |
||||
INFOPLIST_FILE = sipTests/Info.plist; |
||||
IPHONEOS_DEPLOYMENT_TARGET = 13.4; |
||||
LD_RUNPATH_SEARCH_PATHS = ( |
||||
"$(inherited)", |
||||
"@executable_path/Frameworks", |
||||
"@loader_path/Frameworks", |
||||
); |
||||
OTHER_LDFLAGS = ( |
||||
"-ObjC", |
||||
"-lc++", |
||||
"$(inherited)", |
||||
); |
||||
PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; |
||||
PRODUCT_NAME = "$(TARGET_NAME)"; |
||||
TEST_HOST = "$(BUILT_PRODUCTS_DIR)/sip.app/sip"; |
||||
}; |
||||
name = Release; |
||||
}; |
||||
13B07F941A680F5B00A75B9A /* Debug */ = { |
||||
isa = XCBuildConfiguration; |
||||
baseConfigurationReference = 3B4392A12AC88292D35C810B /* Pods-sip.debug.xcconfig */; |
||||
buildSettings = { |
||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; |
||||
CLANG_ENABLE_MODULES = YES; |
||||
CURRENT_PROJECT_VERSION = 1; |
||||
ENABLE_BITCODE = NO; |
||||
INFOPLIST_FILE = sip/Info.plist; |
||||
LD_RUNPATH_SEARCH_PATHS = ( |
||||
"$(inherited)", |
||||
"@executable_path/Frameworks", |
||||
); |
||||
MARKETING_VERSION = 1.0; |
||||
OTHER_LDFLAGS = ( |
||||
"$(inherited)", |
||||
"-ObjC", |
||||
"-lc++", |
||||
); |
||||
PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; |
||||
PRODUCT_NAME = sip; |
||||
SWIFT_OPTIMIZATION_LEVEL = "-Onone"; |
||||
SWIFT_VERSION = 5.0; |
||||
VERSIONING_SYSTEM = "apple-generic"; |
||||
}; |
||||
name = Debug; |
||||
}; |
||||
13B07F951A680F5B00A75B9A /* Release */ = { |
||||
isa = XCBuildConfiguration; |
||||
baseConfigurationReference = 5709B34CF0A7D63546082F79 /* Pods-sip.release.xcconfig */; |
||||
buildSettings = { |
||||
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; |
||||
CLANG_ENABLE_MODULES = YES; |
||||
CURRENT_PROJECT_VERSION = 1; |
||||
INFOPLIST_FILE = sip/Info.plist; |
||||
LD_RUNPATH_SEARCH_PATHS = ( |
||||
"$(inherited)", |
||||
"@executable_path/Frameworks", |
||||
); |
||||
MARKETING_VERSION = 1.0; |
||||
OTHER_LDFLAGS = ( |
||||
"$(inherited)", |
||||
"-ObjC", |
||||
"-lc++", |
||||
); |
||||
PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; |
||||
PRODUCT_NAME = sip; |
||||
SWIFT_VERSION = 5.0; |
||||
VERSIONING_SYSTEM = "apple-generic"; |
||||
}; |
||||
name = Release; |
||||
}; |
||||
83CBBA201A601CBA00E9B192 /* Debug */ = { |
||||
isa = XCBuildConfiguration; |
||||
buildSettings = { |
||||
ALWAYS_SEARCH_USER_PATHS = NO; |
||||
CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; |
||||
CLANG_CXX_LANGUAGE_STANDARD = "c++20"; |
||||
CLANG_CXX_LIBRARY = "libc++"; |
||||
CLANG_ENABLE_MODULES = YES; |
||||
CLANG_ENABLE_OBJC_ARC = YES; |
||||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; |
||||
CLANG_WARN_BOOL_CONVERSION = YES; |
||||
CLANG_WARN_COMMA = YES; |
||||
CLANG_WARN_CONSTANT_CONVERSION = YES; |
||||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; |
||||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; |
||||
CLANG_WARN_EMPTY_BODY = YES; |
||||
CLANG_WARN_ENUM_CONVERSION = YES; |
||||
CLANG_WARN_INFINITE_RECURSION = YES; |
||||
CLANG_WARN_INT_CONVERSION = YES; |
||||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; |
||||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; |
||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; |
||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; |
||||
CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; |
||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; |
||||
CLANG_WARN_STRICT_PROTOTYPES = YES; |
||||
CLANG_WARN_SUSPICIOUS_MOVE = YES; |
||||
CLANG_WARN_UNREACHABLE_CODE = YES; |
||||
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; |
||||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; |
||||
COPY_PHASE_STRIP = NO; |
||||
ENABLE_STRICT_OBJC_MSGSEND = YES; |
||||
ENABLE_TESTABILITY = YES; |
||||
"EXCLUDED_ARCHS[sdk=iphonesimulator*]" = ""; |
||||
GCC_C_LANGUAGE_STANDARD = gnu99; |
||||
GCC_DYNAMIC_NO_PIC = NO; |
||||
GCC_NO_COMMON_BLOCKS = YES; |
||||
GCC_OPTIMIZATION_LEVEL = 0; |
||||
GCC_PREPROCESSOR_DEFINITIONS = ( |
||||
"DEBUG=1", |
||||
"$(inherited)", |
||||
); |
||||
GCC_SYMBOLS_PRIVATE_EXTERN = NO; |
||||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES; |
||||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; |
||||
GCC_WARN_UNDECLARED_SELECTOR = YES; |
||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; |
||||
GCC_WARN_UNUSED_FUNCTION = YES; |
||||
GCC_WARN_UNUSED_VARIABLE = YES; |
||||
IPHONEOS_DEPLOYMENT_TARGET = 13.4; |
||||
LD_RUNPATH_SEARCH_PATHS = ( |
||||
/usr/lib/swift, |
||||
"$(inherited)", |
||||
); |
||||
LIBRARY_SEARCH_PATHS = ( |
||||
"\"$(SDKROOT)/usr/lib/swift\"", |
||||
"\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", |
||||
"\"$(inherited)\"", |
||||
); |
||||
MTL_ENABLE_DEBUG_INFO = YES; |
||||
ONLY_ACTIVE_ARCH = YES; |
||||
OTHER_CPLUSPLUSFLAGS = ( |
||||
"$(OTHER_CFLAGS)", |
||||
"-DFOLLY_NO_CONFIG", |
||||
"-DFOLLY_MOBILE=1", |
||||
"-DFOLLY_USE_LIBCPP=1", |
||||
"-DFOLLY_CFG_NO_COROUTINES=1", |
||||
); |
||||
SDKROOT = iphoneos; |
||||
}; |
||||
name = Debug; |
||||
}; |
||||
83CBBA211A601CBA00E9B192 /* Release */ = { |
||||
isa = XCBuildConfiguration; |
||||
buildSettings = { |
||||
ALWAYS_SEARCH_USER_PATHS = NO; |
||||
CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; |
||||
CLANG_CXX_LANGUAGE_STANDARD = "c++20"; |
||||
CLANG_CXX_LIBRARY = "libc++"; |
||||
CLANG_ENABLE_MODULES = YES; |
||||
CLANG_ENABLE_OBJC_ARC = YES; |
||||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; |
||||
CLANG_WARN_BOOL_CONVERSION = YES; |
||||
CLANG_WARN_COMMA = YES; |
||||
CLANG_WARN_CONSTANT_CONVERSION = YES; |
||||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; |
||||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; |
||||
CLANG_WARN_EMPTY_BODY = YES; |
||||
CLANG_WARN_ENUM_CONVERSION = YES; |
||||
CLANG_WARN_INFINITE_RECURSION = YES; |
||||
CLANG_WARN_INT_CONVERSION = YES; |
||||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; |
||||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; |
||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; |
||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; |
||||
CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; |
||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; |
||||
CLANG_WARN_STRICT_PROTOTYPES = YES; |
||||
CLANG_WARN_SUSPICIOUS_MOVE = YES; |
||||
CLANG_WARN_UNREACHABLE_CODE = YES; |
||||
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; |
||||
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; |
||||
COPY_PHASE_STRIP = YES; |
||||
ENABLE_NS_ASSERTIONS = NO; |
||||
ENABLE_STRICT_OBJC_MSGSEND = YES; |
||||
"EXCLUDED_ARCHS[sdk=iphonesimulator*]" = ""; |
||||
GCC_C_LANGUAGE_STANDARD = gnu99; |
||||
GCC_NO_COMMON_BLOCKS = YES; |
||||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES; |
||||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; |
||||
GCC_WARN_UNDECLARED_SELECTOR = YES; |
||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; |
||||
GCC_WARN_UNUSED_FUNCTION = YES; |
||||
GCC_WARN_UNUSED_VARIABLE = YES; |
||||
IPHONEOS_DEPLOYMENT_TARGET = 13.4; |
||||
LD_RUNPATH_SEARCH_PATHS = ( |
||||
/usr/lib/swift, |
||||
"$(inherited)", |
||||
); |
||||
LIBRARY_SEARCH_PATHS = ( |
||||
"\"$(SDKROOT)/usr/lib/swift\"", |
||||
"\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", |
||||
"\"$(inherited)\"", |
||||
); |
||||
MTL_ENABLE_DEBUG_INFO = NO; |
||||
OTHER_CPLUSPLUSFLAGS = ( |
||||
"$(OTHER_CFLAGS)", |
||||
"-DFOLLY_NO_CONFIG", |
||||
"-DFOLLY_MOBILE=1", |
||||
"-DFOLLY_USE_LIBCPP=1", |
||||
"-DFOLLY_CFG_NO_COROUTINES=1", |
||||
); |
||||
SDKROOT = iphoneos; |
||||
VALIDATE_PRODUCT = YES; |
||||
}; |
||||
name = Release; |
||||
}; |
||||
/* End XCBuildConfiguration section */ |
||||
|
||||
/* Begin XCConfigurationList section */ |
||||
00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "sipTests" */ = { |
||||
isa = XCConfigurationList; |
||||
buildConfigurations = ( |
||||
00E356F61AD99517003FC87E /* Debug */, |
||||
00E356F71AD99517003FC87E /* Release */, |
||||
); |
||||
defaultConfigurationIsVisible = 0; |
||||
defaultConfigurationName = Release; |
||||
}; |
||||
13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "sip" */ = { |
||||
isa = XCConfigurationList; |
||||
buildConfigurations = ( |
||||
13B07F941A680F5B00A75B9A /* Debug */, |
||||
13B07F951A680F5B00A75B9A /* Release */, |
||||
); |
||||
defaultConfigurationIsVisible = 0; |
||||
defaultConfigurationName = Release; |
||||
}; |
||||
83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "sip" */ = { |
||||
isa = XCConfigurationList; |
||||
buildConfigurations = ( |
||||
83CBBA201A601CBA00E9B192 /* Debug */, |
||||
83CBBA211A601CBA00E9B192 /* Release */, |
||||
); |
||||
defaultConfigurationIsVisible = 0; |
||||
defaultConfigurationName = Release; |
||||
}; |
||||
/* End XCConfigurationList section */ |
||||
}; |
||||
rootObject = 83CBB9F71A601CBA00E9B192 /* Project object */; |
||||
} |
@ -0,0 +1,88 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?> |
||||
<Scheme |
||||
LastUpgradeVersion = "1210" |
||||
version = "1.3"> |
||||
<BuildAction |
||||
parallelizeBuildables = "YES" |
||||
buildImplicitDependencies = "YES"> |
||||
<BuildActionEntries> |
||||
<BuildActionEntry |
||||
buildForTesting = "YES" |
||||
buildForRunning = "YES" |
||||
buildForProfiling = "YES" |
||||
buildForArchiving = "YES" |
||||
buildForAnalyzing = "YES"> |
||||
<BuildableReference |
||||
BuildableIdentifier = "primary" |
||||
BlueprintIdentifier = "13B07F861A680F5B00A75B9A" |
||||
BuildableName = "sip.app" |
||||
BlueprintName = "sip" |
||||
ReferencedContainer = "container:sip.xcodeproj"> |
||||
</BuildableReference> |
||||
</BuildActionEntry> |
||||
</BuildActionEntries> |
||||
</BuildAction> |
||||
<TestAction |
||||
buildConfiguration = "Debug" |
||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" |
||||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" |
||||
shouldUseLaunchSchemeArgsEnv = "YES"> |
||||
<Testables> |
||||
<TestableReference |
||||
skipped = "NO"> |
||||
<BuildableReference |
||||
BuildableIdentifier = "primary" |
||||
BlueprintIdentifier = "00E356ED1AD99517003FC87E" |
||||
BuildableName = "sipTests.xctest" |
||||
BlueprintName = "sipTests" |
||||
ReferencedContainer = "container:sip.xcodeproj"> |
||||
</BuildableReference> |
||||
</TestableReference> |
||||
</Testables> |
||||
</TestAction> |
||||
<LaunchAction |
||||
buildConfiguration = "Debug" |
||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" |
||||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" |
||||
launchStyle = "0" |
||||
useCustomWorkingDirectory = "NO" |
||||
ignoresPersistentStateOnLaunch = "NO" |
||||
debugDocumentVersioning = "YES" |
||||
debugServiceExtension = "internal" |
||||
allowLocationSimulation = "YES"> |
||||
<BuildableProductRunnable |
||||
runnableDebuggingMode = "0"> |
||||
<BuildableReference |
||||
BuildableIdentifier = "primary" |
||||
BlueprintIdentifier = "13B07F861A680F5B00A75B9A" |
||||
BuildableName = "sip.app" |
||||
BlueprintName = "sip" |
||||
ReferencedContainer = "container:sip.xcodeproj"> |
||||
</BuildableReference> |
||||
</BuildableProductRunnable> |
||||
</LaunchAction> |
||||
<ProfileAction |
||||
buildConfiguration = "Release" |
||||
shouldUseLaunchSchemeArgsEnv = "YES" |
||||
savedToolIdentifier = "" |
||||
useCustomWorkingDirectory = "NO" |
||||
debugDocumentVersioning = "YES"> |
||||
<BuildableProductRunnable |
||||
runnableDebuggingMode = "0"> |
||||
<BuildableReference |
||||
BuildableIdentifier = "primary" |
||||
BlueprintIdentifier = "13B07F861A680F5B00A75B9A" |
||||
BuildableName = "sip.app" |
||||
BlueprintName = "sip" |
||||
ReferencedContainer = "container:sip.xcodeproj"> |
||||
</BuildableReference> |
||||
</BuildableProductRunnable> |
||||
</ProfileAction> |
||||
<AnalyzeAction |
||||
buildConfiguration = "Debug"> |
||||
</AnalyzeAction> |
||||
<ArchiveAction |
||||
buildConfiguration = "Release" |
||||
revealArchiveInOrganizer = "YES"> |
||||
</ArchiveAction> |
||||
</Scheme> |
@ -0,0 +1,6 @@
|
||||
#import <RCTAppDelegate.h> |
||||
#import <UIKit/UIKit.h> |
||||
|
||||
@interface AppDelegate : RCTAppDelegate |
||||
|
||||
@end |
@ -0,0 +1,31 @@
|
||||
#import "AppDelegate.h" |
||||
|
||||
#import <React/RCTBundleURLProvider.h> |
||||
|
||||
@implementation AppDelegate |
||||
|
||||
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions |
||||
{ |
||||
self.moduleName = @"sip"; |
||||
// 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]; |
||||
} |
||||
|
||||
- (NSURL *)sourceURLForBridge:(RCTBridge *)bridge |
||||
{ |
||||
return [self getBundleURL]; |
||||
} |
||||
|
||||
- (NSURL *)getBundleURL |
||||
{ |
||||
#if DEBUG |
||||
return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index"]; |
||||
#else |
||||
return [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"]; |
||||
#endif |
||||
} |
||||
|
||||
@end |
@ -0,0 +1,53 @@
|
||||
{ |
||||
"images" : [ |
||||
{ |
||||
"idiom" : "iphone", |
||||
"scale" : "2x", |
||||
"size" : "20x20" |
||||
}, |
||||
{ |
||||
"idiom" : "iphone", |
||||
"scale" : "3x", |
||||
"size" : "20x20" |
||||
}, |
||||
{ |
||||
"idiom" : "iphone", |
||||
"scale" : "2x", |
||||
"size" : "29x29" |
||||
}, |
||||
{ |
||||
"idiom" : "iphone", |
||||
"scale" : "3x", |
||||
"size" : "29x29" |
||||
}, |
||||
{ |
||||
"idiom" : "iphone", |
||||
"scale" : "2x", |
||||
"size" : "40x40" |
||||
}, |
||||
{ |
||||
"idiom" : "iphone", |
||||
"scale" : "3x", |
||||
"size" : "40x40" |
||||
}, |
||||
{ |
||||
"idiom" : "iphone", |
||||
"scale" : "2x", |
||||
"size" : "60x60" |
||||
}, |
||||
{ |
||||
"idiom" : "iphone", |
||||
"scale" : "3x", |
||||
"size" : "60x60" |
||||
}, |
||||
{ |
||||
"idiom" : "ios-marketing", |
||||
"scale" : "1x", |
||||
"size" : "1024x1024" |
||||
} |
||||
], |
||||
"info" : { |
||||
"author" : "xcode", |
||||
"version" : 1 |
||||
} |
||||
} |
@ -0,0 +1,6 @@
|
||||
{ |
||||
"info" : { |
||||
"version" : 1, |
||||
"author" : "xcode" |
||||
} |
||||
} |
@ -0,0 +1,52 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?> |
||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> |
||||
<plist version="1.0"> |
||||
<dict> |
||||
<key>CFBundleDevelopmentRegion</key> |
||||
<string>en</string> |
||||
<key>CFBundleDisplayName</key> |
||||
<string>sip</string> |
||||
<key>CFBundleExecutable</key> |
||||
<string>$(EXECUTABLE_NAME)</string> |
||||
<key>CFBundleIdentifier</key> |
||||
<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string> |
||||
<key>CFBundleInfoDictionaryVersion</key> |
||||
<string>6.0</string> |
||||
<key>CFBundleName</key> |
||||
<string>$(PRODUCT_NAME)</string> |
||||
<key>CFBundlePackageType</key> |
||||
<string>APPL</string> |
||||
<key>CFBundleShortVersionString</key> |
||||
<string>$(MARKETING_VERSION)</string> |
||||
<key>CFBundleSignature</key> |
||||
<string>????</string> |
||||
<key>CFBundleVersion</key> |
||||
<string>$(CURRENT_PROJECT_VERSION)</string> |
||||
<key>LSRequiresIPhoneOS</key> |
||||
<true/> |
||||
<key>NSAppTransportSecurity</key> |
||||
<dict> |
||||
<!-- Do not change NSAllowsArbitraryLoads to true, or you will risk app rejection! --> |
||||
<key>NSAllowsArbitraryLoads</key> |
||||
<false/> |
||||
<key>NSAllowsLocalNetworking</key> |
||||
<true/> |
||||
</dict> |
||||
<key>NSLocationWhenInUseUsageDescription</key> |
||||
<string></string> |
||||
<key>UILaunchStoryboardName</key> |
||||
<string>LaunchScreen</string> |
||||
<key>UIRequiredDeviceCapabilities</key> |
||||
<array> |
||||
<string>armv7</string> |
||||
</array> |
||||
<key>UISupportedInterfaceOrientations</key> |
||||
<array> |
||||
<string>UIInterfaceOrientationPortrait</string> |
||||
<string>UIInterfaceOrientationLandscapeLeft</string> |
||||
<string>UIInterfaceOrientationLandscapeRight</string> |
||||
</array> |
||||
<key>UIViewControllerBasedStatusBarAppearance</key> |
||||
<false/> |
||||
</dict> |
||||
</plist> |
@ -0,0 +1,47 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?> |
||||
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="15702" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES" initialViewController="01J-lp-oVM"> |
||||
<device id="retina4_7" orientation="portrait" appearance="light"/> |
||||
<dependencies> |
||||
<deployment identifier="iOS"/> |
||||
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="15704"/> |
||||
<capability name="Safe area layout guides" minToolsVersion="9.0"/> |
||||
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/> |
||||
</dependencies> |
||||
<scenes> |
||||
<!--View Controller--> |
||||
<scene sceneID="EHf-IW-A2E"> |
||||
<objects> |
||||
<viewController id="01J-lp-oVM" sceneMemberID="viewController"> |
||||
<view key="view" contentMode="scaleToFill" id="Ze5-6b-2t3"> |
||||
<rect key="frame" x="0.0" y="0.0" width="375" height="667"/> |
||||
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/> |
||||
<subviews> |
||||
<label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="sip" textAlignment="center" lineBreakMode="middleTruncation" baselineAdjustment="alignBaselines" minimumFontSize="18" translatesAutoresizingMaskIntoConstraints="NO" id="GJd-Yh-RWb"> |
||||
<rect key="frame" x="0.0" y="202" width="375" height="43"/> |
||||
<fontDescription key="fontDescription" type="boldSystem" pointSize="36"/> |
||||
<nil key="highlightedColor"/> |
||||
</label> |
||||
<label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Powered by React Native" textAlignment="center" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" minimumFontSize="9" translatesAutoresizingMaskIntoConstraints="NO" id="MN2-I3-ftu"> |
||||
<rect key="frame" x="0.0" y="626" width="375" height="21"/> |
||||
<fontDescription key="fontDescription" type="system" pointSize="17"/> |
||||
<nil key="highlightedColor"/> |
||||
</label> |
||||
</subviews> |
||||
<color key="backgroundColor" systemColor="systemBackgroundColor" cocoaTouchSystemColor="whiteColor"/> |
||||
<constraints> |
||||
<constraint firstItem="Bcu-3y-fUS" firstAttribute="bottom" secondItem="MN2-I3-ftu" secondAttribute="bottom" constant="20" id="OZV-Vh-mqD"/> |
||||
<constraint firstItem="Bcu-3y-fUS" firstAttribute="centerX" secondItem="GJd-Yh-RWb" secondAttribute="centerX" id="Q3B-4B-g5h"/> |
||||
<constraint firstItem="MN2-I3-ftu" firstAttribute="centerX" secondItem="Bcu-3y-fUS" secondAttribute="centerX" id="akx-eg-2ui"/> |
||||
<constraint firstItem="MN2-I3-ftu" firstAttribute="leading" secondItem="Bcu-3y-fUS" secondAttribute="leading" id="i1E-0Y-4RG"/> |
||||
<constraint firstItem="GJd-Yh-RWb" firstAttribute="centerY" secondItem="Ze5-6b-2t3" secondAttribute="bottom" multiplier="1/3" constant="1" id="moa-c2-u7t"/> |
||||
<constraint firstItem="GJd-Yh-RWb" firstAttribute="leading" secondItem="Bcu-3y-fUS" secondAttribute="leading" symbolic="YES" id="x7j-FC-K8j"/> |
||||
</constraints> |
||||
<viewLayoutGuide key="safeArea" id="Bcu-3y-fUS"/> |
||||
</view> |
||||
</viewController> |
||||
<placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/> |
||||
</objects> |
||||
<point key="canvasLocation" x="52.173913043478265" y="375"/> |
||||
</scene> |
||||
</scenes> |
||||
</document> |
@ -0,0 +1,10 @@
|
||||
#import <UIKit/UIKit.h> |
||||
|
||||
#import "AppDelegate.h" |
||||
|
||||
int main(int argc, char *argv[]) |
||||
{ |
||||
@autoreleasepool { |
||||
return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class])); |
||||
} |
||||
} |
@ -0,0 +1,24 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?> |
||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> |
||||
<plist version="1.0"> |
||||
<dict> |
||||
<key>CFBundleDevelopmentRegion</key> |
||||
<string>en</string> |
||||
<key>CFBundleExecutable</key> |
||||
<string>$(EXECUTABLE_NAME)</string> |
||||
<key>CFBundleIdentifier</key> |
||||
<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string> |
||||
<key>CFBundleInfoDictionaryVersion</key> |
||||
<string>6.0</string> |
||||
<key>CFBundleName</key> |
||||
<string>$(PRODUCT_NAME)</string> |
||||
<key>CFBundlePackageType</key> |
||||
<string>BNDL</string> |
||||
<key>CFBundleShortVersionString</key> |
||||
<string>1.0</string> |
||||
<key>CFBundleSignature</key> |
||||
<string>????</string> |
||||
<key>CFBundleVersion</key> |
||||
<string>1</string> |
||||
</dict> |
||||
</plist> |
@ -0,0 +1,66 @@
|
||||
#import <UIKit/UIKit.h> |
||||
#import <XCTest/XCTest.h> |
||||
|
||||
#import <React/RCTLog.h> |
||||
#import <React/RCTRootView.h> |
||||
|
||||
#define TIMEOUT_SECONDS 600 |
||||
#define TEXT_TO_LOOK_FOR @"Welcome to React" |
||||
|
||||
@interface sipTests : XCTestCase |
||||
|
||||
@end |
||||
|
||||
@implementation sipTests |
||||
|
||||
- (BOOL)findSubviewInView:(UIView *)view matching:(BOOL (^)(UIView *view))test |
||||
{ |
||||
if (test(view)) { |
||||
return YES; |
||||
} |
||||
for (UIView *subview in [view subviews]) { |
||||
if ([self findSubviewInView:subview matching:test]) { |
||||
return YES; |
||||
} |
||||
} |
||||
return NO; |
||||
} |
||||
|
||||
- (void)testRendersWelcomeScreen |
||||
{ |
||||
UIViewController *vc = [[[RCTSharedApplication() delegate] window] rootViewController]; |
||||
NSDate *date = [NSDate dateWithTimeIntervalSinceNow:TIMEOUT_SECONDS]; |
||||
BOOL foundElement = NO; |
||||
|
||||
__block NSString *redboxError = nil; |
||||
#ifdef DEBUG |
||||
RCTSetLogFunction( |
||||
^(RCTLogLevel level, RCTLogSource source, NSString *fileName, NSNumber *lineNumber, NSString *message) { |
||||
if (level >= RCTLogLevelError) { |
||||
redboxError = message; |
||||
} |
||||
}); |
||||
#endif |
||||
|
||||
while ([date timeIntervalSinceNow] > 0 && !foundElement && !redboxError) { |
||||
[[NSRunLoop mainRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]]; |
||||
[[NSRunLoop mainRunLoop] runMode:NSRunLoopCommonModes beforeDate:[NSDate dateWithTimeIntervalSinceNow:0.1]]; |
||||
|
||||
foundElement = [self findSubviewInView:vc.view |
||||
matching:^BOOL(UIView *view) { |
||||
if ([view.accessibilityLabel isEqualToString:TEXT_TO_LOOK_FOR]) { |
||||
return YES; |
||||
} |
||||
return NO; |
||||
}]; |
||||
} |
||||
|
||||
#ifdef DEBUG |
||||
RCTSetLogFunction(RCTDefaultLogFunction); |
||||
#endif |
||||
|
||||
XCTAssertNil(redboxError, @"RedBox error: %@", redboxError); |
||||
XCTAssertTrue(foundElement, @"Couldn't find element with text '%@' in %d seconds", TEXT_TO_LOOK_FOR, TIMEOUT_SECONDS); |
||||
} |
||||
|
||||
@end |
@ -0,0 +1,22 @@
|
||||
const {getDefaultConfig, mergeConfig} = require('@react-native/metro-config'); |
||||
|
||||
const defaultConfig = getDefaultConfig(__dirname); |
||||
const {assetExts, sourceExts} = defaultConfig.resolver; |
||||
|
||||
/** |
||||
* Metro configuration |
||||
* https://facebook.github.io/metro/docs/configuration
|
||||
* |
||||
* @type {import('metro-config').MetroConfig} |
||||
*/ |
||||
const config = { |
||||
transformer: { |
||||
babelTransformerPath: require.resolve('react-native-svg-transformer'), |
||||
}, |
||||
resolver: { |
||||
assetExts: assetExts.filter(ext => ext !== 'svg'), |
||||
sourceExts: [...sourceExts, 'svg'], |
||||
}, |
||||
}; |
||||
|
||||
module.exports = mergeConfig(defaultConfig, config); |
@ -0,0 +1,53 @@
|
||||
{ |
||||
"name": "sip", |
||||
"version": "0.0.1", |
||||
"private": true, |
||||
"scripts": { |
||||
"android": "react-native run-android", |
||||
"ios": "react-native run-ios", |
||||
"lint": "eslint .", |
||||
"start": "react-native start", |
||||
"test": "jest" |
||||
}, |
||||
"dependencies": { |
||||
"@react-native-clipboard/clipboard": "^1.14.1", |
||||
"@react-navigation/native": "^6.1.17", |
||||
"@react-navigation/stack": "^6.3.29", |
||||
"big-integer": "^1.6.52", |
||||
"lodash": "^4.17.21", |
||||
"react": "^18.2.0", |
||||
"react-native": "^0.73.0", |
||||
"react-native-animatable": "^1.4.0", |
||||
"react-native-gesture-handler": "^2.17.1", |
||||
"react-native-incall-manager": "^4.2.0", |
||||
"react-native-jssip": "^3.7.6", |
||||
"react-native-paper": "^5.12.3", |
||||
"react-native-safe-area-context": "^4.10.5", |
||||
"react-native-screens": "^3.32.0", |
||||
"react-native-svg": "^15.3.0", |
||||
"react-native-svg-transformer": "^1.4.0", |
||||
"react-native-vector-icons": "^10.1.0", |
||||
"react-native-webrtc": "^124.0.1", |
||||
"text-encoding": "^0.7.0" |
||||
}, |
||||
"devDependencies": { |
||||
"@babel/core": "^7.20.0", |
||||
"@babel/preset-env": "^7.20.0", |
||||
"@babel/runtime": "^7.20.0", |
||||
"@react-native/babel-preset": "^0.73.18", |
||||
"@react-native/eslint-config": "^0.73.1", |
||||
"@react-native/metro-config": "^0.73.2", |
||||
"@react-native/typescript-config": "^0.73.1", |
||||
"@types/react": "^18.2.6", |
||||
"@types/react-test-renderer": "^18.0.0", |
||||
"babel-jest": "^29.6.3", |
||||
"eslint": "^8.19.0", |
||||
"jest": "^29.6.3", |
||||
"prettier": "2.8.8", |
||||
"react-test-renderer": "18.2.0", |
||||
"typescript": "5.0.4" |
||||
}, |
||||
"engines": { |
||||
"node": ">=18" |
||||
} |
||||
} |
@ -0,0 +1,7 @@
|
||||
module.exports = { |
||||
project: { |
||||
ios: { |
||||
automaticPodsInstallation: true |
||||
} |
||||
} |
||||
} |