upload images in composer v1
This commit is contained in:
		
							parent
							
								
									f5ff0fd274
								
							
						
					
					
						commit
						5ea750599d
					
				
					 10 changed files with 283 additions and 33 deletions
				
			
		|  | @ -1,4 +1,8 @@ | |||
| rootProject.name = 'app' | ||||
| include ':@react-native-camera-roll_camera-roll' | ||||
| project(':@react-native-camera-roll_camera-roll').projectDir = new File(rootProject.projectDir, '../node_modules/@react-native-camera-roll/camera-roll/android') | ||||
| include ':@react-native-camera-roll_camera-roll' | ||||
| project(':@react-native-camera-roll_camera-roll').projectDir = new File(rootProject.projectDir, '../node_modules/@react-native-camera-roll/camera-roll/android') | ||||
| 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') | ||||
|  |  | |||
|  | @ -20,6 +20,8 @@ target 'app' do | |||
|     :app_path => "#{Pod::Config.instance.installation_root}/.." | ||||
|   ) | ||||
| 
 | ||||
|   pod 'react-native-cameraroll', :path => '../node_modules/@react-native-camera-roll/camera-roll' | ||||
| 
 | ||||
|   target 'appTests' do | ||||
|     inherit! :complete | ||||
|     # Pods for testing | ||||
|  |  | |||
|  | @ -220,6 +220,8 @@ PODS: | |||
|   - React-jsinspector (0.68.2) | ||||
|   - React-logger (0.68.2): | ||||
|     - glog | ||||
|   - react-native-cameraroll (5.1.0): | ||||
|     - React-Core | ||||
|   - react-native-pager-view (6.0.2): | ||||
|     - React-Core | ||||
|   - react-native-safe-area-context (4.4.1): | ||||
|  | @ -301,6 +303,15 @@ PODS: | |||
|     - React-Core | ||||
|   - RNGestureHandler (2.6.1): | ||||
|     - React-Core | ||||
|   - RNImageCropPicker (0.38.1): | ||||
|     - React-Core | ||||
|     - React-RCTImage | ||||
|     - RNImageCropPicker/QBImagePickerController (= 0.38.1) | ||||
|     - TOCropViewController | ||||
|   - RNImageCropPicker/QBImagePickerController (0.38.1): | ||||
|     - React-Core | ||||
|     - React-RCTImage | ||||
|     - TOCropViewController | ||||
|   - RNInAppBrowser (3.7.0): | ||||
|     - React-Core | ||||
|   - RNReanimated (2.10.0): | ||||
|  | @ -335,6 +346,7 @@ PODS: | |||
|     - React-RCTImage | ||||
|   - RNSVG (12.4.4): | ||||
|     - React-Core | ||||
|   - TOCropViewController (2.6.1) | ||||
|   - Yoga (1.14.0) | ||||
| 
 | ||||
| DEPENDENCIES: | ||||
|  | @ -359,6 +371,7 @@ DEPENDENCIES: | |||
|   - React-jsiexecutor (from `../node_modules/react-native/ReactCommon/jsiexecutor`) | ||||
|   - React-jsinspector (from `../node_modules/react-native/ReactCommon/jsinspector`) | ||||
|   - React-logger (from `../node_modules/react-native/ReactCommon/logger`) | ||||
|   - "react-native-cameraroll (from `../node_modules/@react-native-camera-roll/camera-roll`)" | ||||
|   - react-native-pager-view (from `../node_modules/react-native-pager-view`) | ||||
|   - react-native-safe-area-context (from `../node_modules/react-native-safe-area-context`) | ||||
|   - react-native-splash-screen (from `../node_modules/react-native-splash-screen`) | ||||
|  | @ -377,6 +390,7 @@ DEPENDENCIES: | |||
|   - "RNCAsyncStorage (from `../node_modules/@react-native-async-storage/async-storage`)" | ||||
|   - "RNCClipboard (from `../node_modules/@react-native-clipboard/clipboard`)" | ||||
|   - RNGestureHandler (from `../node_modules/react-native-gesture-handler`) | ||||
|   - RNImageCropPicker (from `../node_modules/react-native-image-crop-picker`) | ||||
|   - RNInAppBrowser (from `../node_modules/react-native-inappbrowser-reborn`) | ||||
|   - RNReanimated (from `../node_modules/react-native-reanimated`) | ||||
|   - RNScreens (from `../node_modules/react-native-screens`) | ||||
|  | @ -386,6 +400,7 @@ DEPENDENCIES: | |||
| SPEC REPOS: | ||||
|   trunk: | ||||
|     - fmt | ||||
|     - TOCropViewController | ||||
| 
 | ||||
| EXTERNAL SOURCES: | ||||
|   boost: | ||||
|  | @ -426,6 +441,8 @@ EXTERNAL SOURCES: | |||
|     :path: "../node_modules/react-native/ReactCommon/jsinspector" | ||||
|   React-logger: | ||||
|     :path: "../node_modules/react-native/ReactCommon/logger" | ||||
|   react-native-cameraroll: | ||||
|     :path: "../node_modules/@react-native-camera-roll/camera-roll" | ||||
|   react-native-pager-view: | ||||
|     :path: "../node_modules/react-native-pager-view" | ||||
|   react-native-safe-area-context: | ||||
|  | @ -462,6 +479,8 @@ EXTERNAL SOURCES: | |||
|     :path: "../node_modules/@react-native-clipboard/clipboard" | ||||
|   RNGestureHandler: | ||||
|     :path: "../node_modules/react-native-gesture-handler" | ||||
|   RNImageCropPicker: | ||||
|     :path: "../node_modules/react-native-image-crop-picker" | ||||
|   RNInAppBrowser: | ||||
|     :path: "../node_modules/react-native-inappbrowser-reborn" | ||||
|   RNReanimated: | ||||
|  | @ -494,6 +513,7 @@ SPEC CHECKSUMS: | |||
|   React-jsiexecutor: b7b553412f2ec768fe6c8f27cd6bafdb9d8719e6 | ||||
|   React-jsinspector: c5989c77cb89ae6a69561095a61cce56a44ae8e8 | ||||
|   React-logger: a0833912d93b36b791b7a521672d8ee89107aff1 | ||||
|   react-native-cameraroll: a40b082318eb1ecd0336a2f29d9f74b7f2c8cae8 | ||||
|   react-native-pager-view: 592421df0259bf7a7a4fe85b74c24f3f39905605 | ||||
|   react-native-safe-area-context: 99b24a0c5acd0d5dcac2b1a7f18c49ea317be99a | ||||
|   react-native-splash-screen: 4312f786b13a81b5169ef346d76d33bc0c6dc457 | ||||
|  | @ -512,12 +532,14 @@ SPEC CHECKSUMS: | |||
|   RNCAsyncStorage: 0c357f3156fcb16c8589ede67cc036330b6698ca | ||||
|   RNCClipboard: 2834e1c4af68697089cdd455ee4a4cdd198fa7dd | ||||
|   RNGestureHandler: 28ad20bf02257791f7f137b31beef34b9549f54b | ||||
|   RNImageCropPicker: 648356d68fbf9911a1016b3e3723885d28373eda | ||||
|   RNInAppBrowser: e36d6935517101ccba0e875bac8ad7b0cb655364 | ||||
|   RNReanimated: 5bdcbcc3a72aedeee7bb099604262403aa75a1e5 | ||||
|   RNScreens: 0df01424e9e0ed7827200d6ed1087ddd06c493f9 | ||||
|   RNSVG: ecd661f380a07ba690c9c5929c475a44f432d674 | ||||
|   TOCropViewController: edfd4f25713d56905ad1e0b9f5be3fbe0f59c863 | ||||
|   Yoga: 99652481fcd320aefa4a7ef90095b95acd181952 | ||||
| 
 | ||||
| PODFILE CHECKSUM: cf94853ebcb0d8e0d027dca9ab7a4ede886a8f20 | ||||
| PODFILE CHECKSUM: 1c470a84819c5f003f8861cf58774e2fedb862b3 | ||||
| 
 | ||||
| COCOAPODS: 1.11.3 | ||||
|  |  | |||
|  | @ -8,13 +8,13 @@ | |||
| 
 | ||||
| /* Begin PBXBuildFile section */ | ||||
| 		00E356F31AD99517003FC87E /* appTests.m in Sources */ = {isa = PBXBuildFile; fileRef = 00E356F21AD99517003FC87E /* appTests.m */; }; | ||||
| 		03CEA62EF4246066A4356DBF /* libPods-app.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 40C05267EED8EC1DA4212FD4 /* libPods-app.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 */; }; | ||||
| 		5CEAE7B7A55582F96F1D5952 /* libPods-app.a in Frameworks */ = {isa = PBXBuildFile; fileRef = FCB672808307A6013805A3FE /* libPods-app.a */; }; | ||||
| 		64B2214C33449E5F5EB4EA8C /* libPods-app-appTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = D5A91013937D8724CBF0A625 /* libPods-app-appTests.a */; }; | ||||
| 		81AB9BB82411601600AC10FF /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */; }; | ||||
| 		E4BBD590292C1F5200296224 /* app.entitlements in Resources */ = {isa = PBXBuildFile; fileRef = E4437C9E28581FA7006DA9E7 /* app.entitlements */; }; | ||||
| 		FEB90D21557517F9279AECA4 /* libPods-app-appTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = BAD3BC60FA05CF2D4F6F9BA2 /* libPods-app-appTests.a */; }; | ||||
| /* End PBXBuildFile section */ | ||||
| 
 | ||||
| /* Begin PBXContainerItemProxy section */ | ||||
|  | @ -31,21 +31,21 @@ | |||
| 		00E356EE1AD99517003FC87E /* appTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = appTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; | ||||
| 		00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; }; | ||||
| 		00E356F21AD99517003FC87E /* appTests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = appTests.m; sourceTree = "<group>"; }; | ||||
| 		03F7088487057F17D25D2F4B /* Pods-app-appTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-app-appTests.release.xcconfig"; path = "Target Support Files/Pods-app-appTests/Pods-app-appTests.release.xcconfig"; sourceTree = "<group>"; }; | ||||
| 		13B07F961A680F5B00A75B9A /* app.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = app.app; sourceTree = BUILT_PRODUCTS_DIR; }; | ||||
| 		13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = app/AppDelegate.h; sourceTree = "<group>"; }; | ||||
| 		13B07FB01A68108700A75B9A /* AppDelegate.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = AppDelegate.mm; path = app/AppDelegate.mm; sourceTree = "<group>"; }; | ||||
| 		13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = app/Images.xcassets; sourceTree = "<group>"; }; | ||||
| 		13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = app/Info.plist; sourceTree = "<group>"; }; | ||||
| 		13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = app/main.m; sourceTree = "<group>"; }; | ||||
| 		19C43486502F2DE23E091FE3 /* Pods-app-appTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-app-appTests.debug.xcconfig"; path = "Target Support Files/Pods-app-appTests/Pods-app-appTests.debug.xcconfig"; sourceTree = "<group>"; }; | ||||
| 		1F5A3A10A9E763C1649E35A2 /* Pods-app-appTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-app-appTests.release.xcconfig"; path = "Target Support Files/Pods-app-appTests/Pods-app-appTests.release.xcconfig"; sourceTree = "<group>"; }; | ||||
| 		40C05267EED8EC1DA4212FD4 /* libPods-app.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-app.a"; sourceTree = BUILT_PRODUCTS_DIR; }; | ||||
| 		81AB9BB72411601600AC10FF /* LaunchScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = LaunchScreen.storyboard; path = app/LaunchScreen.storyboard; sourceTree = "<group>"; }; | ||||
| 		970005155A83960D1D13380F /* Pods-app.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-app.release.xcconfig"; path = "Target Support Files/Pods-app/Pods-app.release.xcconfig"; sourceTree = "<group>"; }; | ||||
| 		BAD3BC60FA05CF2D4F6F9BA2 /* libPods-app-appTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-app-appTests.a"; sourceTree = BUILT_PRODUCTS_DIR; }; | ||||
| 		9778B24B11B793045DA74F2B /* Pods-app.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-app.debug.xcconfig"; path = "Target Support Files/Pods-app/Pods-app.debug.xcconfig"; sourceTree = "<group>"; }; | ||||
| 		AA52915648F9E2111DA9ADD8 /* Pods-app.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-app.release.xcconfig"; path = "Target Support Files/Pods-app/Pods-app.release.xcconfig"; sourceTree = "<group>"; }; | ||||
| 		CC31CE4B797ED8DCD20C1535 /* Pods-app-appTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-app-appTests.debug.xcconfig"; path = "Target Support Files/Pods-app-appTests/Pods-app-appTests.debug.xcconfig"; sourceTree = "<group>"; }; | ||||
| 		D5A91013937D8724CBF0A625 /* libPods-app-appTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-app-appTests.a"; sourceTree = BUILT_PRODUCTS_DIR; }; | ||||
| 		E4437C9E28581FA7006DA9E7 /* app.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.plist.entitlements; name = app.entitlements; path = app/app.entitlements; sourceTree = "<group>"; }; | ||||
| 		ED22CAA45207BC18E75DB44B /* Pods-app.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-app.debug.xcconfig"; path = "Target Support Files/Pods-app/Pods-app.debug.xcconfig"; sourceTree = "<group>"; }; | ||||
| 		ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; }; | ||||
| 		FCB672808307A6013805A3FE /* libPods-app.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-app.a"; sourceTree = BUILT_PRODUCTS_DIR; }; | ||||
| /* End PBXFileReference section */ | ||||
| 
 | ||||
| /* Begin PBXFrameworksBuildPhase section */ | ||||
|  | @ -53,7 +53,7 @@ | |||
| 			isa = PBXFrameworksBuildPhase; | ||||
| 			buildActionMask = 2147483647; | ||||
| 			files = ( | ||||
| 				FEB90D21557517F9279AECA4 /* libPods-app-appTests.a in Frameworks */, | ||||
| 				64B2214C33449E5F5EB4EA8C /* libPods-app-appTests.a in Frameworks */, | ||||
| 			); | ||||
| 			runOnlyForDeploymentPostprocessing = 0; | ||||
| 		}; | ||||
|  | @ -61,7 +61,7 @@ | |||
| 			isa = PBXFrameworksBuildPhase; | ||||
| 			buildActionMask = 2147483647; | ||||
| 			files = ( | ||||
| 				5CEAE7B7A55582F96F1D5952 /* libPods-app.a in Frameworks */, | ||||
| 				03CEA62EF4246066A4356DBF /* libPods-app.a in Frameworks */, | ||||
| 			); | ||||
| 			runOnlyForDeploymentPostprocessing = 0; | ||||
| 		}; | ||||
|  | @ -103,8 +103,8 @@ | |||
| 			isa = PBXGroup; | ||||
| 			children = ( | ||||
| 				ED297162215061F000B7C4FE /* JavaScriptCore.framework */, | ||||
| 				FCB672808307A6013805A3FE /* libPods-app.a */, | ||||
| 				BAD3BC60FA05CF2D4F6F9BA2 /* libPods-app-appTests.a */, | ||||
| 				40C05267EED8EC1DA4212FD4 /* libPods-app.a */, | ||||
| 				D5A91013937D8724CBF0A625 /* libPods-app-appTests.a */, | ||||
| 			); | ||||
| 			name = Frameworks; | ||||
| 			sourceTree = "<group>"; | ||||
|  | @ -143,10 +143,10 @@ | |||
| 		BBD78D7AC51CEA395F1C20DB /* Pods */ = { | ||||
| 			isa = PBXGroup; | ||||
| 			children = ( | ||||
| 				ED22CAA45207BC18E75DB44B /* Pods-app.debug.xcconfig */, | ||||
| 				970005155A83960D1D13380F /* Pods-app.release.xcconfig */, | ||||
| 				19C43486502F2DE23E091FE3 /* Pods-app-appTests.debug.xcconfig */, | ||||
| 				03F7088487057F17D25D2F4B /* Pods-app-appTests.release.xcconfig */, | ||||
| 				9778B24B11B793045DA74F2B /* Pods-app.debug.xcconfig */, | ||||
| 				AA52915648F9E2111DA9ADD8 /* Pods-app.release.xcconfig */, | ||||
| 				CC31CE4B797ED8DCD20C1535 /* Pods-app-appTests.debug.xcconfig */, | ||||
| 				1F5A3A10A9E763C1649E35A2 /* Pods-app-appTests.release.xcconfig */, | ||||
| 			); | ||||
| 			path = Pods; | ||||
| 			sourceTree = "<group>"; | ||||
|  | @ -158,11 +158,11 @@ | |||
| 			isa = PBXNativeTarget; | ||||
| 			buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "appTests" */; | ||||
| 			buildPhases = ( | ||||
| 				F309585457BFF312EF73FD95 /* [CP] Check Pods Manifest.lock */, | ||||
| 				5D162178C88ED1C10D55B6A4 /* [CP] Check Pods Manifest.lock */, | ||||
| 				00E356EA1AD99517003FC87E /* Sources */, | ||||
| 				00E356EB1AD99517003FC87E /* Frameworks */, | ||||
| 				00E356EC1AD99517003FC87E /* Resources */, | ||||
| 				2772CBCCE24036517E86445D /* [CP] Copy Pods Resources */, | ||||
| 				431D96626A2B8B60C16D4F56 /* [CP] Copy Pods Resources */, | ||||
| 			); | ||||
| 			buildRules = ( | ||||
| 			); | ||||
|  | @ -178,13 +178,13 @@ | |||
| 			isa = PBXNativeTarget; | ||||
| 			buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "app" */; | ||||
| 			buildPhases = ( | ||||
| 				4D45C29570A58E7A8A8D177D /* [CP] Check Pods Manifest.lock */, | ||||
| 				467B75E7982670E38F3A3036 /* [CP] Check Pods Manifest.lock */, | ||||
| 				FD10A7F022414F080027D42C /* Start Packager */, | ||||
| 				13B07F871A680F5B00A75B9A /* Sources */, | ||||
| 				13B07F8C1A680F5B00A75B9A /* Frameworks */, | ||||
| 				13B07F8E1A680F5B00A75B9A /* Resources */, | ||||
| 				00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */, | ||||
| 				9CEFF2A5EA3D60C120442CA6 /* [CP] Copy Pods Resources */, | ||||
| 				55D43DDC59A5C9BA3D615BAB /* [CP] Copy Pods Resources */, | ||||
| 			); | ||||
| 			buildRules = ( | ||||
| 			); | ||||
|  | @ -266,7 +266,7 @@ | |||
| 			shellPath = /bin/sh; | ||||
| 			shellScript = "set -e\n\nexport NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh\n"; | ||||
| 		}; | ||||
| 		2772CBCCE24036517E86445D /* [CP] Copy Pods Resources */ = { | ||||
| 		431D96626A2B8B60C16D4F56 /* [CP] Copy Pods Resources */ = { | ||||
| 			isa = PBXShellScriptBuildPhase; | ||||
| 			buildActionMask = 2147483647; | ||||
| 			files = ( | ||||
|  | @ -283,7 +283,7 @@ | |||
| 			shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-app-appTests/Pods-app-appTests-resources.sh\"\n"; | ||||
| 			showEnvVarsInLog = 0; | ||||
| 		}; | ||||
| 		4D45C29570A58E7A8A8D177D /* [CP] Check Pods Manifest.lock */ = { | ||||
| 		467B75E7982670E38F3A3036 /* [CP] Check Pods Manifest.lock */ = { | ||||
| 			isa = PBXShellScriptBuildPhase; | ||||
| 			buildActionMask = 2147483647; | ||||
| 			files = ( | ||||
|  | @ -305,7 +305,7 @@ | |||
| 			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; | ||||
| 		}; | ||||
| 		9CEFF2A5EA3D60C120442CA6 /* [CP] Copy Pods Resources */ = { | ||||
| 		55D43DDC59A5C9BA3D615BAB /* [CP] Copy Pods Resources */ = { | ||||
| 			isa = PBXShellScriptBuildPhase; | ||||
| 			buildActionMask = 2147483647; | ||||
| 			files = ( | ||||
|  | @ -322,7 +322,7 @@ | |||
| 			shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-app/Pods-app-resources.sh\"\n"; | ||||
| 			showEnvVarsInLog = 0; | ||||
| 		}; | ||||
| 		F309585457BFF312EF73FD95 /* [CP] Check Pods Manifest.lock */ = { | ||||
| 		5D162178C88ED1C10D55B6A4 /* [CP] Check Pods Manifest.lock */ = { | ||||
| 			isa = PBXShellScriptBuildPhase; | ||||
| 			buildActionMask = 2147483647; | ||||
| 			files = ( | ||||
|  | @ -396,7 +396,7 @@ | |||
| /* Begin XCBuildConfiguration section */ | ||||
| 		00E356F61AD99517003FC87E /* Debug */ = { | ||||
| 			isa = XCBuildConfiguration; | ||||
| 			baseConfigurationReference = 19C43486502F2DE23E091FE3 /* Pods-app-appTests.debug.xcconfig */; | ||||
| 			baseConfigurationReference = CC31CE4B797ED8DCD20C1535 /* Pods-app-appTests.debug.xcconfig */; | ||||
| 			buildSettings = { | ||||
| 				ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; | ||||
| 				BUNDLE_LOADER = "$(TEST_HOST)"; | ||||
|  | @ -424,7 +424,7 @@ | |||
| 		}; | ||||
| 		00E356F71AD99517003FC87E /* Release */ = { | ||||
| 			isa = XCBuildConfiguration; | ||||
| 			baseConfigurationReference = 03F7088487057F17D25D2F4B /* Pods-app-appTests.release.xcconfig */; | ||||
| 			baseConfigurationReference = 1F5A3A10A9E763C1649E35A2 /* Pods-app-appTests.release.xcconfig */; | ||||
| 			buildSettings = { | ||||
| 				ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; | ||||
| 				BUNDLE_LOADER = "$(TEST_HOST)"; | ||||
|  | @ -449,7 +449,7 @@ | |||
| 		}; | ||||
| 		13B07F941A680F5B00A75B9A /* Debug */ = { | ||||
| 			isa = XCBuildConfiguration; | ||||
| 			baseConfigurationReference = ED22CAA45207BC18E75DB44B /* Pods-app.debug.xcconfig */; | ||||
| 			baseConfigurationReference = 9778B24B11B793045DA74F2B /* Pods-app.debug.xcconfig */; | ||||
| 			buildSettings = { | ||||
| 				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; | ||||
| 				CLANG_ENABLE_MODULES = YES; | ||||
|  | @ -478,7 +478,7 @@ | |||
| 		}; | ||||
| 		13B07F951A680F5B00A75B9A /* Release */ = { | ||||
| 			isa = XCBuildConfiguration; | ||||
| 			baseConfigurationReference = 970005155A83960D1D13380F /* Pods-app.release.xcconfig */; | ||||
| 			baseConfigurationReference = AA52915648F9E2111DA9ADD8 /* Pods-app.release.xcconfig */; | ||||
| 			buildSettings = { | ||||
| 				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; | ||||
| 				CLANG_ENABLE_MODULES = YES; | ||||
|  |  | |||
|  | @ -48,6 +48,8 @@ | |||
| 			</dict> | ||||
| 		</dict> | ||||
| 	</dict> | ||||
| 	<key>NSPhotoLibraryUsageDescription</key> | ||||
| 	<string></string> | ||||
| 	<key>NSLocationWhenInUseUsageDescription</key> | ||||
| 	<string></string> | ||||
| 	<key>UILaunchStoryboardName</key> | ||||
|  |  | |||
|  | @ -18,6 +18,7 @@ | |||
|     "@fortawesome/react-native-fontawesome": "^0.3.0", | ||||
|     "@gorhom/bottom-sheet": "^4", | ||||
|     "@react-native-async-storage/async-storage": "^1.17.6", | ||||
|     "@react-native-camera-roll/camera-roll": "^5.1.0", | ||||
|     "@react-native-clipboard/clipboard": "^1.10.0", | ||||
|     "@zxing/text-encoding": "^0.9.0", | ||||
|     "base64-js": "^1.5.1", | ||||
|  | @ -33,6 +34,7 @@ | |||
|     "react-native": "0.68.2", | ||||
|     "react-native-appstate-hook": "^1.0.6", | ||||
|     "react-native-gesture-handler": "^2.5.0", | ||||
|     "react-native-image-crop-picker": "^0.38.1", | ||||
|     "react-native-inappbrowser-reborn": "^3.6.3", | ||||
|     "react-native-linear-gradient": "^2.6.2", | ||||
|     "react-native-pager-view": "^6.0.2", | ||||
|  | @ -74,7 +76,9 @@ | |||
|   }, | ||||
|   "jest": { | ||||
|     "preset": "react-native", | ||||
|     "setupFiles": ["./jest.js"], | ||||
|     "setupFiles": [ | ||||
|       "./jest.js" | ||||
|     ], | ||||
|     "moduleFileExtensions": [ | ||||
|       "ts", | ||||
|       "tsx", | ||||
|  |  | |||
							
								
								
									
										25
									
								
								src/state/models/user-local-photos.ts
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								src/state/models/user-local-photos.ts
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,25 @@ | |||
| import {PhotoIdentifier} from './../../../node_modules/@react-native-camera-roll/camera-roll/src/CameraRoll' | ||||
| import {makeAutoObservable} from 'mobx' | ||||
| import {CameraRoll} from '@react-native-camera-roll/camera-roll' | ||||
| import {RootStoreModel} from './root-store' | ||||
| 
 | ||||
| export class UserLocalPhotosModel { | ||||
|   // state
 | ||||
|   photos: PhotoIdentifier[] = [] | ||||
| 
 | ||||
|   constructor(public rootStore: RootStoreModel) { | ||||
|     makeAutoObservable(this, { | ||||
|       rootStore: false, | ||||
|     }) | ||||
|   } | ||||
| 
 | ||||
|   async setup() { | ||||
|     await this._getPhotos() | ||||
|   } | ||||
| 
 | ||||
|   private async _getPhotos() { | ||||
|     CameraRoll.getPhotos({first: 20}).then(r => { | ||||
|       this.photos = r.edges | ||||
|     }) | ||||
|   } | ||||
| } | ||||
|  | @ -9,10 +9,13 @@ import { | |||
|   TextInput, | ||||
|   TouchableOpacity, | ||||
|   View, | ||||
|   ScrollView, | ||||
|   Image, | ||||
| } from 'react-native' | ||||
| import LinearGradient from 'react-native-linear-gradient' | ||||
| import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | ||||
| import {UserAutocompleteViewModel} from '../../../state/models/user-autocomplete-view' | ||||
| import {UserLocalPhotosModel} from '../../../state/models/user-local-photos' | ||||
| import {Autocomplete} from './Autocomplete' | ||||
| import Toast from '../util/Toast' | ||||
| import ProgressCircle from '../util/ProgressCircle' | ||||
|  | @ -22,6 +25,7 @@ import * as apilib from '../../../state/lib/api' | |||
| import {ComposerOpts} from '../../../state/models/shell-ui' | ||||
| import {s, colors, gradients} from '../../lib/styles' | ||||
| import {detectLinkables} from '../../../lib/strings' | ||||
| import {openPicker, openCamera} from 'react-native-image-crop-picker' | ||||
| 
 | ||||
| const MAX_TEXT_LENGTH = 256 | ||||
| const WARNING_TEXT_LENGTH = 200 | ||||
|  | @ -40,15 +44,24 @@ export const ComposePost = observer(function ComposePost({ | |||
|   const [isProcessing, setIsProcessing] = useState(false) | ||||
|   const [error, setError] = useState('') | ||||
|   const [text, setText] = useState('') | ||||
|   const [photoUris, setPhotoUris] = useState<string[]>([]) | ||||
|   const autocompleteView = useMemo<UserAutocompleteViewModel>( | ||||
|     () => new UserAutocompleteViewModel(store), | ||||
|     [], | ||||
|   ) | ||||
|   const localPhotos = useMemo<UserLocalPhotosModel>( | ||||
|     () => new UserLocalPhotosModel(store), | ||||
|     [], | ||||
|   ) | ||||
| 
 | ||||
|   useEffect(() => { | ||||
|     autocompleteView.setup() | ||||
|   }) | ||||
| 
 | ||||
|   useEffect(() => { | ||||
|     localPhotos.setup() | ||||
|   }, []) | ||||
| 
 | ||||
|   const onChangeText = (newText: string) => { | ||||
|     setText(newText) | ||||
| 
 | ||||
|  | @ -183,12 +196,109 @@ export const ComposePost = observer(function ComposePost({ | |||
|           multiline | ||||
|           scrollEnabled | ||||
|           onChangeText={(text: string) => onChangeText(text)} | ||||
|           placeholder={replyTo ? 'Write your reply' : "What's up?"} | ||||
|           placeholder={ | ||||
|             replyTo | ||||
|               ? 'Write your reply' | ||||
|               : photoUris.length === 0 | ||||
|               ? "What's up?" | ||||
|               : 'Add a comment...' | ||||
|           } | ||||
|           style={styles.textInput}> | ||||
|           {textDecorated} | ||||
|         </TextInput> | ||||
|         {photoUris.length !== 0 && ( | ||||
|           <View style={styles.selectedImageContainer}> | ||||
|             {photoUris.length !== 0 && | ||||
|               photoUris.map(item => ( | ||||
|                 <View | ||||
|           style={[s.flexRow, {alignItems: 'center'}, s.pt10, s.pb10, s.pr5]}> | ||||
|                   style={[ | ||||
|                     styles.selectedImage, | ||||
|                     photoUris.length === 1 | ||||
|                       ? styles.selectedImage250 | ||||
|                       : photoUris.length === 2 | ||||
|                       ? styles.selectedImage175 | ||||
|                       : styles.selectedImage85, | ||||
|                   ]}> | ||||
|                   <TouchableOpacity | ||||
|                     onPress={() => { | ||||
|                       setPhotoUris( | ||||
|                         photoUris.filter(filterItem => filterItem !== item), | ||||
|                       ) | ||||
|                     }} | ||||
|                     style={styles.removePhotoButton}> | ||||
|                     <FontAwesomeIcon | ||||
|                       icon="xmark" | ||||
|                       size={16} | ||||
|                       style={{color: colors.white}} | ||||
|                     /> | ||||
|                   </TouchableOpacity> | ||||
| 
 | ||||
|                   <Image | ||||
|                     style={[ | ||||
|                       styles.selectedImage, | ||||
|                       photoUris.length === 1 | ||||
|                         ? styles.selectedImage250 | ||||
|                         : photoUris.length === 2 | ||||
|                         ? styles.selectedImage175 | ||||
|                         : styles.selectedImage85, | ||||
|                     ]} | ||||
|                     source={{uri: item}} | ||||
|                   /> | ||||
|                 </View> | ||||
|               ))} | ||||
|           </View> | ||||
|         )} | ||||
|         {localPhotos.photos != null && text === '' && photoUris.length === 0 && ( | ||||
|           <ScrollView | ||||
|             horizontal | ||||
|             style={styles.photosContainer} | ||||
|             showsHorizontalScrollIndicator={false}> | ||||
|             <TouchableOpacity | ||||
|               style={[styles.galleryButton, styles.photo]} | ||||
|               onPress={() => { | ||||
|                 openCamera({multiple: true, maxFiles: 4}).then() | ||||
|               }}> | ||||
|               <FontAwesomeIcon | ||||
|                 icon="camera" | ||||
|                 size={24} | ||||
|                 style={{color: colors.blue3}} | ||||
|               /> | ||||
|             </TouchableOpacity> | ||||
|             {localPhotos.photos.map(item => ( | ||||
|               <TouchableOpacity | ||||
|                 style={styles.photoButton} | ||||
|                 onPress={() => { | ||||
|                   setPhotoUris([item.node.image.uri, ...photoUris]) | ||||
|                 }}> | ||||
|                 <Image | ||||
|                   style={styles.photo} | ||||
|                   source={{uri: item.node.image.uri}} | ||||
|                 /> | ||||
|               </TouchableOpacity> | ||||
|             ))} | ||||
|             <TouchableOpacity | ||||
|               style={[styles.galleryButton, styles.photo]} | ||||
|               onPress={() => { | ||||
|                 openPicker({multiple: true, maxFiles: 4}).then(items => { | ||||
|                   setPhotoUris([ | ||||
|                     ...items.reduce( | ||||
|                       (accum, cur) => accum.concat(cur.sourceURL!), | ||||
|                       [] as string[], | ||||
|                     ), | ||||
|                     ...photoUris, | ||||
|                   ]) | ||||
|                 }) | ||||
|               }}> | ||||
|               <FontAwesomeIcon | ||||
|                 icon="image" | ||||
|                 style={{color: colors.blue3}} | ||||
|                 size={24} | ||||
|               /> | ||||
|             </TouchableOpacity> | ||||
|           </ScrollView> | ||||
|         )} | ||||
|         <View style={styles.separator} /> | ||||
|         <View style={[s.flexRow, s.pt10, s.pb10, s.pr5, styles.contentCenter]}> | ||||
|           <View style={s.flex1} /> | ||||
|           <Text style={[s.mr10, {color: progressColor}]}> | ||||
|             {MAX_TEXT_LENGTH - text.length} | ||||
|  | @ -275,4 +385,69 @@ const styles = StyleSheet.create({ | |||
|     marginTop: 5, | ||||
|     marginBottom: 10, | ||||
|   }, | ||||
|   contentCenter: {alignItems: 'center'}, | ||||
|   selectedImageContainer: { | ||||
|     flex: 10, | ||||
|     flexDirection: 'row', | ||||
|   }, | ||||
|   selectedImage: { | ||||
|     borderRadius: 8, | ||||
|     margin: 2, | ||||
|   }, | ||||
|   selectedImage250: { | ||||
|     width: 250, | ||||
|     height: 250, | ||||
|   }, | ||||
|   selectedImage175: { | ||||
|     width: 175, | ||||
|     height: 175, | ||||
|   }, | ||||
|   selectedImage85: { | ||||
|     width: 85, | ||||
|     height: 85, | ||||
|   }, | ||||
|   photosContainer: { | ||||
|     width: '100%', | ||||
|     maxHeight: 96, | ||||
|     padding: 8, | ||||
|     overflow: 'hidden', | ||||
|   }, | ||||
|   removePhotoButton: { | ||||
|     position: 'absolute', | ||||
|     top: 8, | ||||
|     right: 8, | ||||
|     width: 24, | ||||
|     height: 24, | ||||
|     borderRadius: 12, | ||||
|     alignItems: 'center', | ||||
|     justifyContent: 'center', | ||||
|     backgroundColor: colors.black, | ||||
|     zIndex: 1, | ||||
|   }, | ||||
|   galleryButton: { | ||||
|     borderWidth: 1, | ||||
|     borderColor: colors.gray3, | ||||
|     alignItems: 'center', | ||||
|     justifyContent: 'center', | ||||
|   }, | ||||
|   photoButton: { | ||||
|     width: 75, | ||||
|     height: 75, | ||||
|     marginRight: 8, | ||||
|     borderWidth: 1, | ||||
|     borderRadius: 16, | ||||
|     borderColor: colors.gray3, | ||||
|   }, | ||||
|   photo: { | ||||
|     width: 75, | ||||
|     height: 75, | ||||
|     marginRight: 8, | ||||
|     borderRadius: 16, | ||||
|   }, | ||||
|   separator: { | ||||
|     borderBottomColor: 'black', | ||||
|     borderBottomWidth: StyleSheet.hairlineWidth, | ||||
|     width: '110%', | ||||
|     marginLeft: -16, | ||||
|   }, | ||||
| }) | ||||
|  |  | |||
|  | @ -56,6 +56,9 @@ import {faUserXmark} from '@fortawesome/free-solid-svg-icons/faUserXmark' | |||
| import {faTicket} from '@fortawesome/free-solid-svg-icons/faTicket' | ||||
| import {faTrashCan} from '@fortawesome/free-regular-svg-icons/faTrashCan' | ||||
| import {faX} from '@fortawesome/free-solid-svg-icons/faX' | ||||
| import {faCamera} from '@fortawesome/free-solid-svg-icons/faCamera' | ||||
| import {faImage} from '@fortawesome/free-solid-svg-icons/faImage' | ||||
| import {faXmark} from '@fortawesome/free-solid-svg-icons/faXmark' | ||||
| 
 | ||||
| export function setup() { | ||||
|   library.add( | ||||
|  | @ -115,5 +118,8 @@ export function setup() { | |||
|     faTicket, | ||||
|     faTrashCan, | ||||
|     faX, | ||||
|     faCamera, | ||||
|     faImage, | ||||
|     faXmark, | ||||
|   ) | ||||
| } | ||||
|  |  | |||
							
								
								
									
										10
									
								
								yarn.lock
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								yarn.lock
									
										
									
									
									
								
							|  | @ -1897,6 +1897,11 @@ | |||
|   dependencies: | ||||
|     merge-options "^3.0.4" | ||||
| 
 | ||||
| "@react-native-camera-roll/camera-roll@^5.1.0": | ||||
|   version "5.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/@react-native-camera-roll/camera-roll/-/camera-roll-5.1.0.tgz#5cfb3cf02d72ab03b3d6a0bdda392e2896c8d55f" | ||||
|   integrity sha512-74pavpt2T2U3V0r5d+pn4NChJbRNcydqakp3NVmosod35Lzxrt9My7kCLDdHXW2S6J6DhgXb/n36/heZQB4AUA== | ||||
| 
 | ||||
| "@react-native-clipboard/clipboard@^1.10.0": | ||||
|   version "1.11.1" | ||||
|   resolved "https://registry.yarnpkg.com/@react-native-clipboard/clipboard/-/clipboard-1.11.1.tgz#d3a9e685ce2383b1e92b89a334896c5575cc103d" | ||||
|  | @ -10186,6 +10191,11 @@ react-native-gradle-plugin@^0.0.6: | |||
|   resolved "https://registry.yarnpkg.com/react-native-gradle-plugin/-/react-native-gradle-plugin-0.0.6.tgz#b61a9234ad2f61430937911003cddd7e15c72b45" | ||||
|   integrity sha512-eIlgtsmDp1jLC24dRn43hB3kEcZVqx6DUQbR0N1ABXGnMEafm9I3V3dUUeD1vh+Dy5WqijSoEwLNUPLgu5zDMg== | ||||
| 
 | ||||
| react-native-image-crop-picker@^0.38.1: | ||||
|   version "0.38.1" | ||||
|   resolved "https://registry.yarnpkg.com/react-native-image-crop-picker/-/react-native-image-crop-picker-0.38.1.tgz#5973b4a8b55835b987e6be2064de411e849ac005" | ||||
|   integrity sha512-cF5UQnWplzHCeiCO+aiGS/0VomWaLmFf3nSsgTMPfY+8+99h8N/eHQvVdSF7RsGw50B8394wGeGyqHjjp8YRWw== | ||||
| 
 | ||||
| react-native-inappbrowser-reborn@^3.6.3: | ||||
|   version "3.7.0" | ||||
|   resolved "https://registry.yarnpkg.com/react-native-inappbrowser-reborn/-/react-native-inappbrowser-reborn-3.7.0.tgz#849a43c3c7da22b65147649fe596836bcb494083" | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue