@plusscommunities/pluss-core-app 7.1.17-auth.0 → 8.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/module/apis/fileActions.js +28 -21
- package/dist/module/apis/fileActions.js.map +1 -1
- package/dist/module/components/ImageUploader.js +13 -22
- package/dist/module/components/ImageUploader.js.map +1 -1
- package/dist/module/config.js +1 -6
- package/dist/module/config.js.map +1 -1
- package/dist/module/session.js +2 -2
- package/dist/module/session.js.map +1 -1
- package/package.json +17 -20
- package/src/apis/fileActions.js +27 -19
- package/src/components/ImageUploader.js +13 -23
- package/src/config.js +0 -5
- package/src/session.js +2 -2
|
@@ -1,42 +1,49 @@
|
|
|
1
|
-
import
|
|
1
|
+
import mime from 'mime-types';
|
|
2
|
+
import { Storage } from 'aws-amplify';
|
|
2
3
|
import { getUrl, generateImageName, randomString } from '../helper';
|
|
3
4
|
import { authedFunction } from '../session';
|
|
5
|
+
import Config from '../config';
|
|
4
6
|
export const fileActions = {
|
|
5
|
-
getPresignedUrl: async (filename, contentType) => {
|
|
6
|
-
// const newFilename = filename.replace(/[^a-z0-9+.]+/gi, '').toLowerCase();
|
|
7
|
-
const signedUrlRes = await authedFunction({
|
|
8
|
-
method: 'GET',
|
|
9
|
-
url: getUrl('media', 'get/presignedurl', {
|
|
10
|
-
filename,
|
|
11
|
-
contentType
|
|
12
|
-
})
|
|
13
|
-
});
|
|
14
|
-
return signedUrlRes.data;
|
|
15
|
-
},
|
|
16
7
|
getUploadUrl: (userId, fileName) => {
|
|
17
8
|
const newFilename = fileName.replace(/[^a-z0-9+.]+/gi, '').toLowerCase();
|
|
18
9
|
return `uploads/users/${userId}/public/${randomString()}/${newFilename}`;
|
|
19
10
|
},
|
|
20
|
-
uploadUserMediaWithProgress: async (
|
|
21
|
-
|
|
11
|
+
uploadUserMediaWithProgress: async (imageUri, url, progressCallback = null) => {
|
|
12
|
+
const blob = await fileActions.imageToBlob(imageUri);
|
|
13
|
+
return fileActions.uploadBlobAWS(Config.env.awsUploadsBucket, url, blob, '', progressCallback);
|
|
22
14
|
},
|
|
15
|
+
// uploadUserMedia: async (userId, image, fileName) => {
|
|
16
|
+
// const blob = await fileActions.imageToBlob(image.uri);
|
|
17
|
+
// const url = fileActions.getUploadUrl(userId, fileName);
|
|
18
|
+
// return fileActions.uploadBlobAWS(Config.env.awsUploadsBucket, url, blob);
|
|
19
|
+
// },
|
|
20
|
+
// uploadSignatureImage: async (image, name) => {
|
|
21
|
+
// const blob = await fileActions.imageToBlob(image);
|
|
22
|
+
// const newImageName = generateImageName(name, 'signature.png');
|
|
23
|
+
// return fileActions.uploadBlobAWS(Config.env.awsStorageBucket, newImageName, blob, 'images/');
|
|
24
|
+
// },
|
|
23
25
|
imageToBlob: async imageUri => {
|
|
24
26
|
const response = await fetch(imageUri);
|
|
25
27
|
return response.blob();
|
|
26
28
|
},
|
|
27
|
-
uploadBlobAWS:
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
29
|
+
uploadBlobAWS: (bucket, uri, blob, prefix = '', progressCallback = null) => {
|
|
30
|
+
const imageName = prefix ? uri.replace(/^.*[\\/]/, '') : uri;
|
|
31
|
+
const fileType = mime.lookup(uri);
|
|
32
|
+
const access = {
|
|
33
|
+
level: 'public',
|
|
34
|
+
bucket,
|
|
35
|
+
contentType: fileType,
|
|
36
|
+
customPrefix: {
|
|
37
|
+
public: ''
|
|
31
38
|
},
|
|
32
|
-
|
|
33
|
-
onUploadProgress: progress => progressCallback && progressCallback({
|
|
39
|
+
progressCallback: progress => progressCallback && progressCallback({
|
|
34
40
|
uri,
|
|
35
41
|
loaded: progress.loaded,
|
|
36
42
|
total: progress.total,
|
|
37
43
|
percentage: `${Math.floor(progress.loaded / progress.total * 100)}%`
|
|
38
44
|
})
|
|
39
|
-
}
|
|
45
|
+
};
|
|
46
|
+
return Storage.put(`${prefix}${imageName}`, blob, access);
|
|
40
47
|
},
|
|
41
48
|
getStockPhotos: async () => {
|
|
42
49
|
const response = await authedFunction({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["mime","Storage","getUrl","generateImageName","randomString","authedFunction","Config","fileActions","getUploadUrl","userId","fileName","newFilename","replace","toLowerCase","uploadUserMediaWithProgress","imageUri","url","progressCallback","blob","imageToBlob","uploadBlobAWS","env","awsUploadsBucket","response","fetch","bucket","uri","prefix","imageName","fileType","lookup","access","level","contentType","customPrefix","public","progress","loaded","total","percentage","Math","floor","put","getStockPhotos","method","images","data","map","image","getMediaFolders","site","query"],"sources":["fileActions.js"],"sourcesContent":["import mime from 'mime-types';\nimport { Storage } from 'aws-amplify';\nimport { getUrl, generateImageName, randomString } from '../helper';\nimport { authedFunction } from '../session';\nimport Config from '../config';\n\nexport const fileActions = {\n getUploadUrl: (userId, fileName) => {\n const newFilename = fileName.replace(/[^a-z0-9+.]+/gi, '').toLowerCase();\n return `uploads/users/${userId}/public/${randomString()}/${newFilename}`;\n },\n uploadUserMediaWithProgress: async (imageUri, url, progressCallback = null) => {\n const blob = await fileActions.imageToBlob(imageUri);\n return fileActions.uploadBlobAWS(Config.env.awsUploadsBucket, url, blob, '', progressCallback);\n },\n // uploadUserMedia: async (userId, image, fileName) => {\n // const blob = await fileActions.imageToBlob(image.uri);\n // const url = fileActions.getUploadUrl(userId, fileName);\n // return fileActions.uploadBlobAWS(Config.env.awsUploadsBucket, url, blob);\n // },\n // uploadSignatureImage: async (image, name) => {\n // const blob = await fileActions.imageToBlob(image);\n // const newImageName = generateImageName(name, 'signature.png');\n // return fileActions.uploadBlobAWS(Config.env.awsStorageBucket, newImageName, blob, 'images/');\n // },\n imageToBlob: async imageUri => {\n const response = await fetch(imageUri);\n return response.blob();\n },\n uploadBlobAWS: (bucket, uri, blob, prefix = '', progressCallback = null) => {\n const imageName = prefix ? uri.replace(/^.*[\\\\/]/, '') : uri;\n const fileType = mime.lookup(uri);\n const access = {\n level: 'public',\n bucket,\n contentType: fileType,\n customPrefix: { public: '' },\n progressCallback: progress =>\n progressCallback &&\n progressCallback({\n uri,\n loaded: progress.loaded,\n total: progress.total,\n percentage: `${Math.floor((progress.loaded / progress.total) * 100)}%`,\n }),\n };\n return Storage.put(`${prefix}${imageName}`, blob, access);\n },\n getStockPhotos: async () => {\n const response = await authedFunction({\n method: 'GET',\n url: 'https://pluss60.pluss60-api.com/media-demo/library',\n });\n // Convert to images object\n const images = response.data.map(image => {\n return { uri: image };\n });\n return images;\n },\n getMediaFolders: site => {\n const query = { site };\n return authedFunction({\n method: 'GET',\n url: getUrl('media', 'folders', query),\n });\n },\n // addMediaFolder: (site, name, images) => {\n // return authedFunction({\n // method: 'POST',\n // url: getUrl('media', 'addFolder'),\n // data: {\n // site,\n // name,\n // images,\n // },\n // });\n // },\n // addImagesToFolder: (id, site, images) => {\n // return authedFunction({\n // method: 'POST',\n // url: getUrl('media', 'addImages'),\n // data: {\n // id,\n // site,\n // images,\n // },\n // });\n // },\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -108,21 +108,19 @@ class ImageUploader extends Component {
|
|
|
108
108
|
let uploadUri;
|
|
109
109
|
try {
|
|
110
110
|
const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;
|
|
111
|
+
uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
|
|
112
|
+
this.props.onUploadStarted(uploadUri, imageUri);
|
|
111
113
|
this.hideUploadMenu();
|
|
112
114
|
const resized = await this.resizeImageAsync(imageUri);
|
|
113
|
-
const blob = await fileActions.imageToBlob(resized.uri);
|
|
114
|
-
const presignedUriRes = await fileActions.getPresignedUrl(_.last(resized.uri.split('/')), blob.type);
|
|
115
|
-
uploadUri = presignedUriRes.key;
|
|
116
|
-
this.props.onUploadStarted(uploadUri, imageUri);
|
|
117
115
|
if (this.props.onlySelectImage) {
|
|
118
116
|
this.props.onImageSelected(resized, fileName);
|
|
119
117
|
return;
|
|
120
118
|
}
|
|
121
|
-
const
|
|
119
|
+
const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {
|
|
122
120
|
if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
|
|
123
121
|
});
|
|
124
|
-
this.props.onUploadSuccess(Config.env.baseUploadsUrl +
|
|
125
|
-
console.log('upload success', Config.env.baseUploadsUrl +
|
|
122
|
+
this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
|
|
123
|
+
console.log('upload success', Config.env.baseUploadsUrl + res.key);
|
|
126
124
|
} catch (e) {
|
|
127
125
|
console.log('handleImagePicked error', e);
|
|
128
126
|
this.props.onUploadFailed(uploadUri);
|
|
@@ -133,6 +131,7 @@ class ImageUploader extends Component {
|
|
|
133
131
|
const imagesUploaded = imagesSelected.map(image => {
|
|
134
132
|
const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;
|
|
135
133
|
const uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
|
|
134
|
+
if (!this.props.onlySelectImage) this.props.onUploadStarted(uploadUri, image.uri);
|
|
136
135
|
return {
|
|
137
136
|
imageUri: image.uri,
|
|
138
137
|
uploadUri,
|
|
@@ -151,19 +150,15 @@ class ImageUploader extends Component {
|
|
|
151
150
|
} = image;
|
|
152
151
|
try {
|
|
153
152
|
const resized = await this.resizeImageAsync(imageUri);
|
|
154
|
-
const blob = await fileActions.imageToBlob(resized.uri);
|
|
155
153
|
if (this.props.onlySelectImage) {
|
|
156
154
|
this.props.onImageSelected(resized, fileName);
|
|
157
155
|
return;
|
|
158
156
|
}
|
|
159
|
-
const
|
|
160
|
-
const uploadUri = presignedUriRes.key;
|
|
161
|
-
if (!this.props.onlySelectImage) this.props.onUploadStarted(uploadUri, imageUri);
|
|
162
|
-
const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {
|
|
157
|
+
const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {
|
|
163
158
|
if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
|
|
164
159
|
});
|
|
165
|
-
this.props.onUploadSuccess(Config.env.baseUploadsUrl +
|
|
166
|
-
console.log('upload success', Config.env.baseUploadsUrl +
|
|
160
|
+
this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
|
|
161
|
+
console.log('upload success', Config.env.baseUploadsUrl + res.key);
|
|
167
162
|
} catch (e) {
|
|
168
163
|
console.log('handleMultiImagePicked error', e);
|
|
169
164
|
this.props.onUploadFailed(uploadUri);
|
|
@@ -175,16 +170,14 @@ class ImageUploader extends Component {
|
|
|
175
170
|
try {
|
|
176
171
|
const fileType = uri.substring(uri.lastIndexOf('.') + 1);
|
|
177
172
|
const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_VIDEO_NAME)}.${fileType}`;
|
|
178
|
-
|
|
179
|
-
const presignedUriRes = await fileActions.getPresignedUrl(fileName, blob.type);
|
|
180
|
-
uploadUri = presignedUriRes.key;
|
|
173
|
+
uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
|
|
181
174
|
this.props.onUploadStarted(uploadUri, uri);
|
|
182
175
|
this.hideUploadMenu();
|
|
183
|
-
const
|
|
176
|
+
const res = await fileActions.uploadUserMediaWithProgress(uri, uploadUri, progress => {
|
|
184
177
|
if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
|
|
185
178
|
});
|
|
186
|
-
this.props.onUploadSuccess(Config.env.baseUploadsUrl +
|
|
187
|
-
console.log('upload success', Config.env.baseUploadsUrl +
|
|
179
|
+
this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
|
|
180
|
+
console.log('upload success', Config.env.baseUploadsUrl + res.key);
|
|
188
181
|
} catch (e) {
|
|
189
182
|
console.log('handleVideoPicked error', e);
|
|
190
183
|
this.props.onUploadFailed(uploadUri);
|
|
@@ -202,7 +195,6 @@ class ImageUploader extends Component {
|
|
|
202
195
|
return true;
|
|
203
196
|
});
|
|
204
197
|
_defineProperty(this, "isEditingEnabled", () => {
|
|
205
|
-
return false;
|
|
206
198
|
return !this.props.multiple && !this.props.allowVideo && getValueOrDefault(this.props.allowsEditing, DEFAULT_ALLOWS_EDITING);
|
|
207
199
|
});
|
|
208
200
|
_defineProperty(this, "openCamera", async () => {
|
|
@@ -337,7 +329,6 @@ class ImageUploader extends Component {
|
|
|
337
329
|
} else {
|
|
338
330
|
if (mediaSelected[0].mediaType === MediaLibrary.MediaType.video) {
|
|
339
331
|
const uri = mediaSelected[0].localUri || mediaSelected[0].uri;
|
|
340
|
-
console.log('picked a video');
|
|
341
332
|
this.handleVideoPicked(uri);
|
|
342
333
|
} else {
|
|
343
334
|
this.handleMultiImagePicked(mediaSelected);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Component","View","ScrollView","TouchableOpacity","Text","Platform","Linking","Modal","Dimensions","StyleSheet","ImageBackground","connect","Icon","_","Camera","MediaLibrary","ImageManipulator","ImagePicker","ImageBrowser","ExpoImageManipulator","Header","Popup","PopupMenu","InlineButton","getValueOrDefault","getThumb300","isVideo","getMainBrandingColourFromState","BOXGREY","INACTIVE_BUTTON","TEXT_BLUEGREY","TEXT_DARK","LINEGREY","Config","fileActions","stockImagesLoaded","imageLibraryLoaded","SCREEN_WIDTH","get","width","SCREEN_HEIGHT","height","DEFAULT_ASPECT","DEFAULT_ALLOWS_EDITING","DEFAULT_ALLOWS_IOS_CAMERA_EDITING","DEFAULT_EXIF","DEFULAT_IMAGE_TYPE","DEFAULT_IMAGE_NAME","DEFAULT_VIDEO_NAME","DEFAULT_SIZE","DEFAULT_COMPRESSION","ImageUploader","constructor","props","_defineProperty","hasPermission","getPermissionsAsync","granted","setState","loadingLocalFolders","localAlbums","getAlbumsAsync","includeSmartAlbums","title","id","error","console","log","loadingRemoteFolders","stockImages","getStockPhotos","libraryRes","getMediaFolders","user","site","data","mediaUri","uploadUri","uri","resizeImageAsync","res","uploadUserMediaWithProgress","progress","onUploadProgress","onUploadSuccess","env","baseUploadsUrl","key","e","onUploadFailed","actions","resize","size","saveOptions","format","compress","quality","base64","manipulateAsync","imageUri","fileName","hideUploadMenu","resized","blob","imageToBlob","presignedUriRes","getPresignedUrl","last","split","type","onUploadStarted","onlySelectImage","onImageSelected","uploadResult","url","imagesSelected","imagesUploaded","map","image","getUploadUrl","userId","i","length","fileType","substring","lastIndexOf","_this$state$localAlbu","cameraPermission","requestCameraPermissionsAsync","rollPermission","requestPermissionsAsync","status","OS","showWarningPopup","state","loadLocalAlbums","multiple","allowVideo","allowsEditing","askPermissionsAsync","editingAllowed","isEditingEnabled","allowsEditingIOSCamera","result","launchCameraAsync","aspect","exif","canceled","isEmpty","assets","handleImagePicked","mediaTypes","MediaTypeOptions","Videos","showUploadMenu","setTimeout","showPhotos","selected","showRemote","selectedAlbumId","launchImageLibraryAsync","All","Images","cancelled","handleVideoPicked","handleMultiImagePicked","showCropper","showSelectAlbum","videoSelected","onAttach","selectedType","callback","openCropper","mediaSelected","onLibrarySelected","media","mediaType","MediaType","video","localUri","hidePhotos","deleteIndex","indexOf","splice","options","text","onPress","openCamera","push","openVideoCamera","openPhotos","hideLibrary","openLibrary","selectedItemNumber","createElement","style","styles","selectedItemContainer","selectedMarkerContainer","backgroundColor","colourBrandingMain","selectedItemText","name","iconStyle","selectedItemIcon","warning","componentDidMount","loadRemoteAlbums","camera","roll","innerWarning","closeWarningPopup","goToPermissionSettings","openURL","renderSelectionPreview","horizontal","showsHorizontalScrollIndicator","contentContainerStyle","selectionPreviewContainer","previewItemContainer","previewItemImage","source","previewItemRemoveButton","onRemoveImage","previewItemRemoveContainer","previewItemRemoveIcon","renderSelectedAlbum","selectedAlbum","imageLibrary","find","album","selectedAlbumText","onSelectAlbum","selectAlbumButton","selectAlbumButtonText","selectAlbumButtonIcon","renderBrowser","imagesLimit","max","loadCount","onChange","onSelectionChange","renderSelectedComponent","onSelected","browserContainer","itemStyle","itemContainer","itemWidth","itemHeight","remoteAlbums","renderAttachButton","canAttach","attachText","buttonContainer","color","fillTouchable","large","disabled","renderSelectAlbumPopup","visible","transparent","animationType","onRequestClose","onSelectAlbumClosed","selectAlbumModal","selectAlbumContainer","selectAlbumTitleContainer","selectAlbumTitle","index","onAlbumSelected","albumOptionContainer","borderTopWidth","albumOptionText","marginHorizontal","renderPhotos","leftIcon","onPressLeft","popupTitle","contentContainer","render","action","bind","bold","buildOptions","onClose","cancelText","photo","onToggleModal","toggleCropper","isVisible","onPictureChoosed","create","flex","padding","position","top","right","borderRadius","alignItems","justifyContent","fontFamily","fontSize","marginBottom","paddingHorizontal","paddingTop","flexDirection","marginRight","bottom","left","zIndex","borderTopLeftRadius","borderTopRightRadius","maxHeight","borderColor","borderBottomWidth","textAlign","paddingVertical","paddingRight","paddingLeft","overflow","borderWidth","mapStateToProps","filter","folder","Public","Name","RowId","images","forwardRef"],"sources":["ImageUploader.js"],"sourcesContent":["import React, { Component } from 'react';\nimport { View, ScrollView, TouchableOpacity, Text, Platform, Linking, Modal, Dimensions, StyleSheet, ImageBackground } from 'react-native';\nimport { connect } from 'react-redux';\nimport { Icon } from '@rneui/themed';\nimport _ from 'lodash';\nimport { Camera } from 'expo-camera';\nimport * as MediaLibrary from 'expo-media-library';\nimport * as ImageManipulator from 'expo-image-manipulator';\nimport * as ImagePicker from 'expo-image-picker';\nimport ImageBrowser from './expo-image-picker-multiple/ImageBrowser';\nimport ExpoImageManipulator from './react-native-expo-image-cropper/ExpoImageManipulator';\nimport Header from './Header';\nimport { Popup } from './Popup';\nimport { PopupMenu } from './PopupMenu';\nimport { InlineButton } from './InlineButton';\nimport { getValueOrDefault, getThumb300, isVideo } from '../helper';\nimport { getMainBrandingColourFromState, BOXGREY, INACTIVE_BUTTON, TEXT_BLUEGREY, TEXT_DARK, LINEGREY } from '../colours';\nimport Config from '../config';\nimport { fileActions } from '../apis';\nimport { stockImagesLoaded, imageLibraryLoaded } from '../actions';\n\nconst SCREEN_WIDTH = Dimensions.get('window').width;\nconst SCREEN_HEIGHT = Dimensions.get('window').height;\nconst DEFAULT_ASPECT = [1, 1];\nconst DEFAULT_ALLOWS_EDITING = true;\nconst DEFAULT_ALLOWS_IOS_CAMERA_EDITING = false;\nconst DEFAULT_EXIF = true;\nconst DEFULAT_IMAGE_TYPE = 'jpeg';\nconst DEFAULT_IMAGE_NAME = 'image';\nconst DEFAULT_VIDEO_NAME = 'video';\nconst DEFAULT_SIZE = {\n width: 1400,\n};\nconst DEFAULT_COMPRESSION = 0.8;\n\nclass ImageUploader extends Component {\n constructor(props) {\n super(props);\n\n this.state = {\n showUploadMenu: false,\n warning: null,\n showPhotos: false,\n showRemote: false,\n selected: [],\n selectedType: '',\n onAttach: null,\n selectedAlbumId: '',\n showSelectAlbum: false,\n showCropper: false,\n localAlbums: [],\n loadingLocalFolders: false,\n loadingRemoteFolders: false,\n };\n }\n\n componentDidMount() {\n this.loadLocalAlbums();\n this.loadRemoteAlbums();\n }\n\n loadLocalAlbums = async () => {\n const hasPermission = await MediaLibrary.getPermissionsAsync();\n if (!hasPermission.granted) return;\n\n this.setState({ loadingLocalFolders: true }, async () => {\n try {\n const localAlbums = await MediaLibrary.getAlbumsAsync({ includeSmartAlbums: true });\n this.setState({\n loadingLocalFolders: false,\n localAlbums: [\n {\n title: 'All Photos',\n id: '',\n },\n ...localAlbums,\n ],\n });\n } catch (error) {\n console.log('loadLocalAlbums - error', error);\n this.setState({ loadingLocalFolders: false });\n }\n });\n };\n\n loadRemoteAlbums = () => {\n this.setState({ loadingRemoteFolders: true }, async () => {\n try {\n const stockImages = await fileActions.getStockPhotos();\n this.props.stockImagesLoaded(stockImages);\n const libraryRes = await fileActions.getMediaFolders(this.props.user.site);\n this.props.imageLibraryLoaded(libraryRes.data);\n } catch (error) {\n console.log('loadRemoteAlbums - error', error);\n } finally {\n this.setState({ loadingRemoteFolders: false });\n }\n });\n };\n\n showUploadMenu() {\n this.setState({\n showUploadMenu: true,\n });\n }\n\n hideUploadMenu() {\n this.setState({\n showUploadMenu: false,\n });\n }\n\n retryUpload = async (mediaUri, uploadUri) => {\n try {\n const uri = isVideo(uploadUri) ? mediaUri : (await this.resizeImageAsync(mediaUri)).uri;\n const res = await fileActions.uploadUserMediaWithProgress(uri, uploadUri, progress => {\n if (this.props.onUploadProgress) this.props.onUploadProgress(progress);\n });\n this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);\n console.log('upload(retry) success', Config.env.baseUploadsUrl + res.key);\n } catch (e) {\n console.log('retryUpload error', e);\n this.props.onUploadFailed(uploadUri);\n }\n };\n\n resizeImageAsync = async uri => {\n const actions = [\n {\n resize: getValueOrDefault(this.props.size, DEFAULT_SIZE),\n },\n ];\n const saveOptions = {\n format: DEFULAT_IMAGE_TYPE,\n compress: getValueOrDefault(this.props.quality, DEFAULT_COMPRESSION),\n base64: true,\n };\n return await ImageManipulator.manipulateAsync(uri, actions, saveOptions);\n };\n\n handleImagePicked = async imageUri => {\n let uploadUri;\n try {\n const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;\n\n this.hideUploadMenu();\n\n const resized = await this.resizeImageAsync(imageUri);\n const blob = await fileActions.imageToBlob(resized.uri);\n const presignedUriRes = await fileActions.getPresignedUrl(_.last(resized.uri.split('/')), blob.type);\n uploadUri = presignedUriRes.key;\n this.props.onUploadStarted(uploadUri, imageUri);\n if (this.props.onlySelectImage) {\n this.props.onImageSelected(resized, fileName);\n return;\n }\n\n const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {\n if (this.props.onUploadProgress) this.props.onUploadProgress(progress);\n });\n\n this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);\n console.log('upload success', Config.env.baseUploadsUrl + uploadUri);\n } catch (e) {\n console.log('handleImagePicked error', e);\n this.props.onUploadFailed(uploadUri);\n }\n };\n\n handleMultiImagePicked = async imagesSelected => {\n // Signal start of all images selected\n const imagesUploaded = imagesSelected.map(image => {\n const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;\n const uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);\n return { imageUri: image.uri, uploadUri, fileName };\n });\n this.hideUploadMenu();\n\n // Sequentially upload all imagesUploaded\n for (let i = 0; i < imagesUploaded.length; i++) {\n const image = imagesUploaded[i];\n const { imageUri, uploadUri, fileName } = image;\n try {\n const resized = await this.resizeImageAsync(imageUri);\n const blob = await fileActions.imageToBlob(resized.uri);\n if (this.props.onlySelectImage) {\n this.props.onImageSelected(resized, fileName);\n return;\n }\n const presignedUriRes = await fileActions.getPresignedUrl(_.last(resized.uri.split('/')), blob.type);\n const uploadUri = presignedUriRes.key;\n if (!this.props.onlySelectImage) this.props.onUploadStarted(uploadUri, imageUri);\n\n const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {\n if (this.props.onUploadProgress) this.props.onUploadProgress(progress);\n });\n\n this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);\n console.log('upload success', Config.env.baseUploadsUrl + uploadUri);\n } catch (e) {\n console.log('handleMultiImagePicked error', e);\n this.props.onUploadFailed(uploadUri);\n }\n }\n };\n\n handleVideoPicked = async uri => {\n let uploadUri;\n try {\n const fileType = uri.substring(uri.lastIndexOf('.') + 1);\n const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_VIDEO_NAME)}.${fileType}`;\n const blob = await fileActions.imageToBlob(uri);\n const presignedUriRes = await fileActions.getPresignedUrl(fileName, blob.type);\n uploadUri = presignedUriRes.key;\n\n this.props.onUploadStarted(uploadUri, uri);\n this.hideUploadMenu();\n\n const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {\n if (this.props.onUploadProgress) this.props.onUploadProgress(progress);\n });\n\n this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);\n console.log('upload success', Config.env.baseUploadsUrl + uploadUri);\n } catch (e) {\n console.log('handleVideoPicked error', e);\n this.props.onUploadFailed(uploadUri);\n }\n };\n\n showWarningPopup(camera, roll) {\n if (Platform.OS !== 'ios') {\n return;\n }\n let innerWarning = '';\n if (camera && roll) {\n innerWarning = 'both your camera and photo library';\n } else if (camera) {\n innerWarning = 'your camera';\n } else if (roll) {\n innerWarning = 'your photo library';\n } else {\n // nothing to warn about\n return;\n }\n this.setState({\n warning: `You must grant access to ${innerWarning}. Tap Go to settings to change your permission settings.`,\n });\n }\n\n closeWarningPopup() {\n this.setState({\n warning: null,\n });\n }\n\n goToPermissionSettings() {\n Linking.openURL('app-settings:');\n this.setState({\n warning: null,\n });\n }\n\n askPermissionsAsync = async () => {\n const cameraPermission = await Camera.requestCameraPermissionsAsync();\n const rollPermission = await MediaLibrary.requestPermissionsAsync();\n if (cameraPermission.status !== 'granted' || (Platform.OS === 'ios' && rollPermission.status !== 'granted')) {\n this.showWarningPopup(cameraPermission.status !== 'granted', rollPermission.status !== 'granted');\n return false;\n }\n if (this.state.localAlbums?.length <= 0) this.loadLocalAlbums();\n\n return true;\n };\n\n isEditingEnabled = () => {\n return false;\n return !this.props.multiple && !this.props.allowVideo && getValueOrDefault(this.props.allowsEditing, DEFAULT_ALLOWS_EDITING);\n };\n\n openCamera = async () => {\n if (!(await this.askPermissionsAsync())) return;\n\n let editingAllowed = this.isEditingEnabled();\n if (Platform.OS === 'ios') {\n editingAllowed = getValueOrDefault(\n this.props.allowsEditingIOSCamera,\n getValueOrDefault(this.props.allowsEditing, DEFAULT_ALLOWS_IOS_CAMERA_EDITING),\n );\n }\n const result = await ImagePicker.launchCameraAsync({\n allowsEditing: editingAllowed,\n aspect: getValueOrDefault(this.props.aspect, DEFAULT_ASPECT),\n exif: getValueOrDefault(this.props.exif, DEFAULT_EXIF),\n });\n\n if (!result.canceled && !_.isEmpty(result.assets)) {\n this.handleImagePicked(result.assets[0].uri);\n }\n };\n\n openVideoCamera = async () => {\n if (!(await this.askPermissionsAsync())) return;\n\n const result = await ImagePicker.launchCameraAsync({\n allowsEditing: this.isEditingEnabled(),\n mediaTypes: ImagePicker.MediaTypeOptions.Videos,\n });\n\n if (!result.canceled && !_.isEmpty(result.assets)) {\n this.handleImagePicked(result.assets[0].uri);\n }\n };\n\n openLibrary = async () => {\n this.setState(\n {\n showUploadMenu: false,\n },\n () => {\n setTimeout(() => {\n this.setState({\n showPhotos: true,\n selected: [],\n showRemote: true,\n selectedAlbumId: '',\n });\n }, 1000);\n },\n );\n };\n\n openPhotos = async () => {\n if (Platform.OS === 'android') {\n const result = await ImagePicker.launchImageLibraryAsync({\n allowsEditing: this.isEditingEnabled(),\n aspect: getValueOrDefault(this.props.aspect, DEFAULT_ASPECT),\n exif: getValueOrDefault(this.props.exif, DEFAULT_EXIF),\n mediaTypes: this.props.allowVideo ? ImagePicker.MediaTypeOptions.All : ImagePicker.MediaTypeOptions.Images,\n });\n if (!result.cancelled) {\n if (result.assets.length === 1 && result.assets[0].type === 'video') {\n this.handleVideoPicked(result.assets[0].uri);\n } else {\n this.handleMultiImagePicked(result.assets);\n }\n }\n return;\n }\n\n // iOS behaviour\n if (!(await this.askPermissionsAsync())) return;\n\n this.setState(\n {\n showUploadMenu: false,\n },\n () => {\n setTimeout(() => {\n this.setState({\n showPhotos: true,\n selected: [],\n showRemote: false,\n selectedAlbumId: '',\n });\n }, 1000);\n },\n );\n };\n\n hidePhotos = () => {\n this.setState({ showPhotos: false });\n };\n\n openCropper = () => {\n // Switching modals - requires a timeout to ensure the modal is closed before opening the next one\n this.setState(\n {\n showPhotos: false,\n },\n () => {\n setTimeout(() => {\n this.setState({\n showCropper: true,\n });\n }, 1000);\n },\n );\n };\n\n toggleCropper = () => {\n this.setState({ showCropper: !this.state.showCropper });\n };\n\n onSelectAlbum = () => {\n this.setState({ showSelectAlbum: true });\n };\n\n onSelectAlbumClosed = () => {\n this.setState({ showSelectAlbum: false });\n };\n\n onAlbumSelected = selectedAlbumId => {\n this.setState({ showSelectAlbum: false, selectedAlbumId });\n };\n\n onSelectionChange = (selected, videoSelected, onAttach) => {\n this.setState({\n selected,\n selectedType: videoSelected ? 'video' : 'image',\n onAttach,\n });\n };\n\n onSelected = async callback => {\n if (this.isEditingEnabled()) {\n this.openCropper();\n } else {\n const mediaSelected = await callback;\n // console.log('mediaSelected', mediaSelected);\n if (this.state.showRemote) {\n if (this.props.onLibrarySelected) {\n mediaSelected.map(media => {\n this.props.onLibrarySelected(media.uri);\n });\n }\n } else {\n if (mediaSelected[0].mediaType === MediaLibrary.MediaType.video) {\n const uri = mediaSelected[0].localUri || mediaSelected[0].uri;\n console.log('picked a video');\n this.handleVideoPicked(uri);\n } else {\n this.handleMultiImagePicked(mediaSelected);\n }\n }\n\n this.hidePhotos();\n }\n };\n\n onRemoveImage = uri => {\n const selected = [...this.state.selected];\n const deleteIndex = selected.indexOf(uri);\n selected.splice(deleteIndex, 1);\n this.setState({ selected });\n };\n\n buildOptions = () => {\n const options = [\n {\n text: 'Take photo',\n onPress: this.openCamera,\n },\n ];\n if (this.props.allowVideo)\n options.push({\n text: 'Record video',\n onPress: this.openVideoCamera,\n });\n options.push({\n text: 'Camera Roll',\n onPress: this.openPhotos,\n });\n if (!this.props.hideLibrary)\n options.push({\n text: 'Image Library',\n onPress: this.openLibrary,\n });\n\n return options;\n };\n\n renderSelectionPreview() {\n const { selected, showRemote } = this.state;\n\n return (\n <View>\n <ScrollView horizontal showsHorizontalScrollIndicator={false} contentContainerStyle={styles.selectionPreviewContainer}>\n {selected &&\n selected.map(uri => {\n const imageUri = showRemote ? getThumb300(uri) : uri;\n return (\n <View key={uri} style={styles.previewItemContainer}>\n <ImageBackground style={styles.previewItemImage} source={{ uri: imageUri }} />\n <TouchableOpacity style={styles.previewItemRemoveButton} onPress={() => this.onRemoveImage(uri)}>\n <View style={[styles.previewItemRemoveContainer, { backgroundColor: this.props.colourBrandingMain }]}>\n <Icon name=\"times\" type=\"font-awesome\" iconStyle={styles.previewItemRemoveIcon} />\n </View>\n </TouchableOpacity>\n </View>\n );\n })}\n </ScrollView>\n </View>\n );\n }\n\n renderSelectedAlbum() {\n const { localAlbums, selectedAlbumId, showRemote } = this.state;\n const selectedAlbum = (showRemote ? this.props.imageLibrary : localAlbums).find(album => album.id === selectedAlbumId);\n const selectedAlbumText = selectedAlbum ? selectedAlbum.title : '';\n\n return (\n <TouchableOpacity onPress={this.onSelectAlbum}>\n <View style={styles.selectAlbumButton}>\n <Text style={styles.selectAlbumButtonText}>{selectedAlbumText}</Text>\n <Icon name=\"angle-down\" type=\"font-awesome\" iconStyle={styles.selectAlbumButtonIcon} />\n </View>\n </TouchableOpacity>\n );\n }\n\n renderSelectedComponent = selectedItemNumber => {\n return (\n <View style={styles.selectedItemContainer}>\n <View style={[styles.selectedMarkerContainer, { backgroundColor: this.props.colourBrandingMain }]}>\n {this.props.multiple ? (\n <Text style={styles.selectedItemText}>{selectedItemNumber}</Text>\n ) : (\n <Icon name=\"check\" type=\"font-awesome\" iconStyle={styles.selectedItemIcon} />\n )}\n </View>\n </View>\n );\n };\n\n renderBrowser() {\n const { selected, selectedAlbumId, showRemote } = this.state;\n const { imagesLimit, multiple, allowVideo, imageLibrary } = this.props;\n const width = (SCREEN_WIDTH - 10 * 2) / 4;\n\n return (\n <ImageBrowser\n max={!multiple ? 1 : imagesLimit}\n loadCount={30}\n onChange={this.onSelectionChange}\n renderSelectedComponent={this.renderSelectedComponent}\n callback={this.onSelected}\n selected={selected}\n allowVideo={allowVideo}\n style={styles.browserContainer}\n itemStyle={styles.itemContainer}\n itemWidth={width}\n itemHeight={width}\n album={selectedAlbumId}\n remoteAlbums={showRemote ? imageLibrary : null}\n />\n );\n }\n\n renderAttachButton() {\n const { selected, selectedType } = this.state;\n const canAttach = selected.length > 0 && !_.isEmpty(selectedType);\n const attachText = `Attach ${canAttach ? selected.length : ''} ${canAttach ? selectedType : ''}${selected.length > 1 ? 's' : ''}`;\n\n return (\n <View style={styles.buttonContainer}>\n <InlineButton\n color={canAttach ? this.props.colourBrandingMain : INACTIVE_BUTTON}\n onPress={this.state.onAttach}\n fillTouchable\n large\n disabled={!canAttach}\n >\n {attachText}\n </InlineButton>\n </View>\n );\n }\n\n renderSelectAlbumPopup() {\n const { showSelectAlbum, localAlbums, showRemote } = this.state;\n if (!showSelectAlbum) return null;\n\n return (\n <Modal visible transparent animationType=\"slide\" onRequestClose={this.onSelectAlbumClosed}>\n <View style={styles.selectAlbumModal}>\n <View style={styles.selectAlbumContainer}>\n <View style={styles.selectAlbumTitleContainer}>\n <Text style={styles.selectAlbumTitle}>Select Album</Text>\n </View>\n <ScrollView>\n {(showRemote ? this.props.imageLibrary : localAlbums).map((album, index) => {\n return (\n <TouchableOpacity key={album.id} onPress={() => this.onAlbumSelected(album.id)}>\n <View style={[styles.albumOptionContainer, index === 0 && { borderTopWidth: 0 }]}>\n <Text style={styles.albumOptionText}>{album.title}</Text>\n </View>\n </TouchableOpacity>\n );\n })}\n </ScrollView>\n <TouchableOpacity onPress={this.onSelectAlbumClosed}>\n <View style={[styles.albumOptionContainer, { marginHorizontal: 0 }]}>\n <Text style={[styles.albumOptionText, { color: this.props.colourBrandingMain }]}>Cancel</Text>\n </View>\n </TouchableOpacity>\n </View>\n </View>\n </Modal>\n );\n }\n\n renderPhotos() {\n return (\n <Modal visible transparent animationType=\"slide\" onRequestClose={this.hidePhotos}>\n <Header leftIcon=\"angle-left\" onPressLeft={this.hidePhotos} text={this.props.popupTitle || 'Attach image'} />\n <View style={styles.contentContainer}>\n {this.renderSelectionPreview()}\n {this.renderSelectedAlbum()}\n {this.renderBrowser()}\n </View>\n {this.renderAttachButton()}\n {this.renderSelectAlbumPopup()}\n </Modal>\n );\n }\n\n render() {\n const { warning, showUploadMenu, showPhotos, showCropper, selected } = this.state;\n\n if (warning != null) {\n return (\n <Popup\n title=\"Permissions missing\"\n text={warning}\n options={[\n {\n text: 'Go to settings',\n action: this.goToPermissionSettings.bind(this),\n bold: true,\n },\n {\n text: 'Ignore',\n action: this.closeWarningPopup.bind(this),\n },\n ]}\n />\n );\n }\n\n if (showUploadMenu) {\n const options = this.buildOptions();\n return <PopupMenu onClose={this.hideUploadMenu.bind(this)} options={options} title={this.props.popupTitle} cancelText=\"Cancel\" />;\n }\n\n if (showPhotos) return this.renderPhotos();\n\n if (showCropper) {\n return (\n <ExpoImageManipulator\n photo={{ uri: selected[0] }}\n onToggleModal={this.toggleCropper}\n isVisible={showCropper}\n onPictureChoosed={data => {\n this.handleImagePicked(data.uri);\n }}\n />\n );\n }\n\n return null;\n }\n}\n\nconst styles = StyleSheet.create({\n contentContainer: {\n flex: 1,\n backgroundColor: BOXGREY,\n },\n browserContainer: {\n padding: 10,\n },\n itemContainer: {\n padding: 4,\n },\n selectedItemContainer: {\n flex: 1,\n backgroundColor: '#0008',\n },\n selectedMarkerContainer: {\n position: 'absolute',\n top: 6,\n right: 6,\n width: 20,\n height: 20,\n borderRadius: 10,\n alignItems: 'center',\n justifyContent: 'center',\n },\n selectedItemText: {\n fontFamily: 'sf-semibold',\n fontSize: 12,\n color: '#fff',\n marginBottom: 1,\n },\n selectedItemIcon: {\n fontSize: 12,\n color: '#fff',\n marginBottom: 1,\n },\n buttonContainer: {\n alignItems: 'center',\n justifyContent: 'center',\n height: 60,\n paddingHorizontal: 14,\n backgroundColor: '#fff',\n },\n selectAlbumButton: {\n paddingTop: 13,\n paddingHorizontal: 14,\n flexDirection: 'row',\n alignItems: 'center',\n },\n selectAlbumButtonText: {\n fontFamily: 'sf-medium',\n fontSize: 14,\n color: TEXT_BLUEGREY,\n marginRight: 6,\n },\n selectAlbumButtonIcon: {\n fontSize: 20,\n color: TEXT_BLUEGREY,\n },\n selectAlbumModal: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n top: 0,\n backgroundColor: 'rgba(0,0,0,0.5)',\n zIndex: 1000,\n },\n selectAlbumContainer: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n backgroundColor: '#fff',\n borderTopLeftRadius: 12,\n borderTopRightRadius: 12,\n maxHeight: SCREEN_HEIGHT / 2,\n },\n selectAlbumTitleContainer: {\n padding: 16,\n borderColor: LINEGREY,\n borderBottomWidth: 1,\n },\n selectAlbumTitle: {\n fontFamily: 'sf-semibold',\n fontSize: 16,\n textAlign: 'center',\n color: TEXT_DARK,\n },\n albumOptionContainer: {\n marginHorizontal: 16,\n paddingVertical: 16,\n borderColor: LINEGREY,\n borderTopWidth: 1,\n },\n albumOptionText: {\n fontFamily: 'sf-regular',\n fontSize: 16,\n textAlign: 'center',\n color: TEXT_DARK,\n },\n selectionPreviewContainer: {\n paddingTop: 14,\n paddingRight: 2,\n paddingLeft: 14,\n },\n previewItemContainer: {\n marginRight: 12,\n },\n previewItemImage: {\n width: 50,\n height: 50,\n alignItems: 'center',\n justifyContent: 'center',\n borderRadius: 4,\n overflow: 'hidden',\n },\n previewItemRemoveButton: {\n position: 'absolute',\n top: -8,\n right: -8,\n },\n previewItemRemoveContainer: {\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 10,\n width: 20,\n height: 20,\n borderWidth: 2,\n borderColor: '#fff',\n },\n previewItemRemoveIcon: {\n fontSize: 10,\n color: '#fff',\n marginBottom: 1,\n },\n});\n\nconst mapStateToProps = state => {\n const { user, media } = state;\n const imageLibrary = media.imageLibrary\n .filter(folder => !folder.Public)\n .map(album => {\n return {\n title: album.Name,\n id: album.RowId || '',\n images: album.RowId ? album.Images : media.stockImages,\n };\n });\n\n return {\n user,\n imageLibrary,\n colourBrandingMain: getMainBrandingColourFromState(state),\n };\n};\n\nexport default connect(mapStateToProps, { stockImagesLoaded, imageLibraryLoaded }, null, { forwardRef: true })(ImageUploader);\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["React","Component","View","ScrollView","TouchableOpacity","Text","Platform","Linking","Modal","Dimensions","StyleSheet","ImageBackground","connect","Icon","_","Camera","MediaLibrary","ImageManipulator","ImagePicker","ImageBrowser","ExpoImageManipulator","Header","Popup","PopupMenu","InlineButton","getValueOrDefault","getThumb300","isVideo","getMainBrandingColourFromState","BOXGREY","INACTIVE_BUTTON","TEXT_BLUEGREY","TEXT_DARK","LINEGREY","Config","fileActions","stockImagesLoaded","imageLibraryLoaded","SCREEN_WIDTH","get","width","SCREEN_HEIGHT","height","DEFAULT_ASPECT","DEFAULT_ALLOWS_EDITING","DEFAULT_ALLOWS_IOS_CAMERA_EDITING","DEFAULT_EXIF","DEFULAT_IMAGE_TYPE","DEFAULT_IMAGE_NAME","DEFAULT_VIDEO_NAME","DEFAULT_SIZE","DEFAULT_COMPRESSION","ImageUploader","constructor","props","_defineProperty","hasPermission","getPermissionsAsync","granted","setState","loadingLocalFolders","localAlbums","getAlbumsAsync","includeSmartAlbums","title","id","error","console","log","loadingRemoteFolders","stockImages","getStockPhotos","libraryRes","getMediaFolders","user","site","data","mediaUri","uploadUri","uri","resizeImageAsync","res","uploadUserMediaWithProgress","progress","onUploadProgress","onUploadSuccess","env","baseUploadsUrl","key","e","onUploadFailed","actions","resize","size","saveOptions","format","compress","quality","base64","manipulateAsync","imageUri","fileName","getUploadUrl","userId","onUploadStarted","hideUploadMenu","resized","onlySelectImage","onImageSelected","imagesSelected","imagesUploaded","map","image","i","length","fileType","substring","lastIndexOf","_this$state$localAlbu","cameraPermission","requestCameraPermissionsAsync","rollPermission","requestPermissionsAsync","status","OS","showWarningPopup","state","loadLocalAlbums","multiple","allowVideo","allowsEditing","askPermissionsAsync","editingAllowed","isEditingEnabled","allowsEditingIOSCamera","result","launchCameraAsync","aspect","exif","canceled","isEmpty","assets","handleImagePicked","mediaTypes","MediaTypeOptions","Videos","showUploadMenu","setTimeout","showPhotos","selected","showRemote","selectedAlbumId","launchImageLibraryAsync","All","Images","cancelled","type","handleVideoPicked","handleMultiImagePicked","showCropper","showSelectAlbum","videoSelected","onAttach","selectedType","callback","openCropper","mediaSelected","onLibrarySelected","media","mediaType","MediaType","video","localUri","hidePhotos","deleteIndex","indexOf","splice","options","text","onPress","openCamera","push","openVideoCamera","openPhotos","hideLibrary","openLibrary","selectedItemNumber","createElement","style","styles","selectedItemContainer","selectedMarkerContainer","backgroundColor","colourBrandingMain","selectedItemText","name","iconStyle","selectedItemIcon","warning","componentDidMount","loadRemoteAlbums","camera","roll","innerWarning","closeWarningPopup","goToPermissionSettings","openURL","renderSelectionPreview","horizontal","showsHorizontalScrollIndicator","contentContainerStyle","selectionPreviewContainer","previewItemContainer","previewItemImage","source","previewItemRemoveButton","onRemoveImage","previewItemRemoveContainer","previewItemRemoveIcon","renderSelectedAlbum","selectedAlbum","imageLibrary","find","album","selectedAlbumText","onSelectAlbum","selectAlbumButton","selectAlbumButtonText","selectAlbumButtonIcon","renderBrowser","imagesLimit","max","loadCount","onChange","onSelectionChange","renderSelectedComponent","onSelected","browserContainer","itemStyle","itemContainer","itemWidth","itemHeight","remoteAlbums","renderAttachButton","canAttach","attachText","buttonContainer","color","fillTouchable","large","disabled","renderSelectAlbumPopup","visible","transparent","animationType","onRequestClose","onSelectAlbumClosed","selectAlbumModal","selectAlbumContainer","selectAlbumTitleContainer","selectAlbumTitle","index","onAlbumSelected","albumOptionContainer","borderTopWidth","albumOptionText","marginHorizontal","renderPhotos","leftIcon","onPressLeft","popupTitle","contentContainer","render","action","bind","bold","buildOptions","onClose","cancelText","photo","onToggleModal","toggleCropper","isVisible","onPictureChoosed","create","flex","padding","position","top","right","borderRadius","alignItems","justifyContent","fontFamily","fontSize","marginBottom","paddingHorizontal","paddingTop","flexDirection","marginRight","bottom","left","zIndex","borderTopLeftRadius","borderTopRightRadius","maxHeight","borderColor","borderBottomWidth","textAlign","paddingVertical","paddingRight","paddingLeft","overflow","borderWidth","mapStateToProps","filter","folder","Public","Name","RowId","images","forwardRef"],"sources":["ImageUploader.js"],"sourcesContent":["import React, { Component } from 'react';\nimport { View, ScrollView, TouchableOpacity, Text, Platform, Linking, Modal, Dimensions, StyleSheet, ImageBackground } from 'react-native';\nimport { connect } from 'react-redux';\nimport { Icon } from '@rneui/themed';\nimport _ from 'lodash';\nimport { Camera } from 'expo-camera';\nimport * as MediaLibrary from 'expo-media-library';\nimport * as ImageManipulator from 'expo-image-manipulator';\nimport * as ImagePicker from 'expo-image-picker';\nimport ImageBrowser from './expo-image-picker-multiple/ImageBrowser';\nimport ExpoImageManipulator from './react-native-expo-image-cropper/ExpoImageManipulator';\nimport Header from './Header';\nimport { Popup } from './Popup';\nimport { PopupMenu } from './PopupMenu';\nimport { InlineButton } from './InlineButton';\nimport { getValueOrDefault, getThumb300, isVideo } from '../helper';\nimport { getMainBrandingColourFromState, BOXGREY, INACTIVE_BUTTON, TEXT_BLUEGREY, TEXT_DARK, LINEGREY } from '../colours';\nimport Config from '../config';\nimport { fileActions } from '../apis';\nimport { stockImagesLoaded, imageLibraryLoaded } from '../actions';\n\nconst SCREEN_WIDTH = Dimensions.get('window').width;\nconst SCREEN_HEIGHT = Dimensions.get('window').height;\nconst DEFAULT_ASPECT = [1, 1];\nconst DEFAULT_ALLOWS_EDITING = true;\nconst DEFAULT_ALLOWS_IOS_CAMERA_EDITING = false;\nconst DEFAULT_EXIF = true;\nconst DEFULAT_IMAGE_TYPE = 'jpeg';\nconst DEFAULT_IMAGE_NAME = 'image';\nconst DEFAULT_VIDEO_NAME = 'video';\nconst DEFAULT_SIZE = {\n width: 1400,\n};\nconst DEFAULT_COMPRESSION = 0.8;\n\nclass ImageUploader extends Component {\n constructor(props) {\n super(props);\n\n this.state = {\n showUploadMenu: false,\n warning: null,\n showPhotos: false,\n showRemote: false,\n selected: [],\n selectedType: '',\n onAttach: null,\n selectedAlbumId: '',\n showSelectAlbum: false,\n showCropper: false,\n localAlbums: [],\n loadingLocalFolders: false,\n loadingRemoteFolders: false,\n };\n }\n\n componentDidMount() {\n this.loadLocalAlbums();\n this.loadRemoteAlbums();\n }\n\n loadLocalAlbums = async () => {\n const hasPermission = await MediaLibrary.getPermissionsAsync();\n if (!hasPermission.granted) return;\n\n this.setState({ loadingLocalFolders: true }, async () => {\n try {\n const localAlbums = await MediaLibrary.getAlbumsAsync({ includeSmartAlbums: true });\n this.setState({\n loadingLocalFolders: false,\n localAlbums: [\n {\n title: 'All Photos',\n id: '',\n },\n ...localAlbums,\n ],\n });\n } catch (error) {\n console.log('loadLocalAlbums - error', error);\n this.setState({ loadingLocalFolders: false });\n }\n });\n };\n\n loadRemoteAlbums = () => {\n this.setState({ loadingRemoteFolders: true }, async () => {\n try {\n const stockImages = await fileActions.getStockPhotos();\n this.props.stockImagesLoaded(stockImages);\n const libraryRes = await fileActions.getMediaFolders(this.props.user.site);\n this.props.imageLibraryLoaded(libraryRes.data);\n } catch (error) {\n console.log('loadRemoteAlbums - error', error);\n } finally {\n this.setState({ loadingRemoteFolders: false });\n }\n });\n };\n\n showUploadMenu() {\n this.setState({\n showUploadMenu: true,\n });\n }\n\n hideUploadMenu() {\n this.setState({\n showUploadMenu: false,\n });\n }\n\n retryUpload = async (mediaUri, uploadUri) => {\n try {\n const uri = isVideo(uploadUri) ? mediaUri : (await this.resizeImageAsync(mediaUri)).uri;\n const res = await fileActions.uploadUserMediaWithProgress(uri, uploadUri, progress => {\n if (this.props.onUploadProgress) this.props.onUploadProgress(progress);\n });\n this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);\n console.log('upload(retry) success', Config.env.baseUploadsUrl + res.key);\n } catch (e) {\n console.log('retryUpload error', e);\n this.props.onUploadFailed(uploadUri);\n }\n };\n\n resizeImageAsync = async uri => {\n const actions = [\n {\n resize: getValueOrDefault(this.props.size, DEFAULT_SIZE),\n },\n ];\n const saveOptions = {\n format: DEFULAT_IMAGE_TYPE,\n compress: getValueOrDefault(this.props.quality, DEFAULT_COMPRESSION),\n base64: true,\n };\n return await ImageManipulator.manipulateAsync(uri, actions, saveOptions);\n };\n\n handleImagePicked = async imageUri => {\n let uploadUri;\n try {\n const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;\n uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);\n\n this.props.onUploadStarted(uploadUri, imageUri);\n this.hideUploadMenu();\n\n const resized = await this.resizeImageAsync(imageUri);\n if (this.props.onlySelectImage) {\n this.props.onImageSelected(resized, fileName);\n return;\n }\n\n const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {\n if (this.props.onUploadProgress) this.props.onUploadProgress(progress);\n });\n\n this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);\n console.log('upload success', Config.env.baseUploadsUrl + res.key);\n } catch (e) {\n console.log('handleImagePicked error', e);\n this.props.onUploadFailed(uploadUri);\n }\n };\n\n handleMultiImagePicked = async imagesSelected => {\n // Signal start of all images selected\n const imagesUploaded = imagesSelected.map(image => {\n const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;\n const uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);\n if (!this.props.onlySelectImage) this.props.onUploadStarted(uploadUri, image.uri);\n return { imageUri: image.uri, uploadUri, fileName };\n });\n this.hideUploadMenu();\n\n // Sequentially upload all imagesUploaded\n for (let i = 0; i < imagesUploaded.length; i++) {\n const image = imagesUploaded[i];\n const { imageUri, uploadUri, fileName } = image;\n try {\n const resized = await this.resizeImageAsync(imageUri);\n if (this.props.onlySelectImage) {\n this.props.onImageSelected(resized, fileName);\n return;\n }\n\n const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {\n if (this.props.onUploadProgress) this.props.onUploadProgress(progress);\n });\n this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);\n console.log('upload success', Config.env.baseUploadsUrl + res.key);\n } catch (e) {\n console.log('handleMultiImagePicked error', e);\n this.props.onUploadFailed(uploadUri);\n }\n }\n };\n\n handleVideoPicked = async uri => {\n let uploadUri;\n try {\n const fileType = uri.substring(uri.lastIndexOf('.') + 1);\n const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_VIDEO_NAME)}.${fileType}`;\n uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);\n\n this.props.onUploadStarted(uploadUri, uri);\n this.hideUploadMenu();\n\n const res = await fileActions.uploadUserMediaWithProgress(uri, uploadUri, progress => {\n if (this.props.onUploadProgress) this.props.onUploadProgress(progress);\n });\n\n this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);\n console.log('upload success', Config.env.baseUploadsUrl + res.key);\n } catch (e) {\n console.log('handleVideoPicked error', e);\n this.props.onUploadFailed(uploadUri);\n }\n };\n\n showWarningPopup(camera, roll) {\n if (Platform.OS !== 'ios') {\n return;\n }\n let innerWarning = '';\n if (camera && roll) {\n innerWarning = 'both your camera and photo library';\n } else if (camera) {\n innerWarning = 'your camera';\n } else if (roll) {\n innerWarning = 'your photo library';\n } else {\n // nothing to warn about\n return;\n }\n this.setState({\n warning: `You must grant access to ${innerWarning}. Tap Go to settings to change your permission settings.`,\n });\n }\n\n closeWarningPopup() {\n this.setState({\n warning: null,\n });\n }\n\n goToPermissionSettings() {\n Linking.openURL('app-settings:');\n this.setState({\n warning: null,\n });\n }\n\n askPermissionsAsync = async () => {\n const cameraPermission = await Camera.requestCameraPermissionsAsync();\n const rollPermission = await MediaLibrary.requestPermissionsAsync();\n if (cameraPermission.status !== 'granted' || (Platform.OS === 'ios' && rollPermission.status !== 'granted')) {\n this.showWarningPopup(cameraPermission.status !== 'granted', rollPermission.status !== 'granted');\n return false;\n }\n if (this.state.localAlbums?.length <= 0) this.loadLocalAlbums();\n\n return true;\n };\n\n isEditingEnabled = () => {\n return !this.props.multiple && !this.props.allowVideo && getValueOrDefault(this.props.allowsEditing, DEFAULT_ALLOWS_EDITING);\n };\n\n openCamera = async () => {\n if (!(await this.askPermissionsAsync())) return;\n\n let editingAllowed = this.isEditingEnabled();\n if (Platform.OS === 'ios') {\n editingAllowed = getValueOrDefault(\n this.props.allowsEditingIOSCamera,\n getValueOrDefault(this.props.allowsEditing, DEFAULT_ALLOWS_IOS_CAMERA_EDITING),\n );\n }\n const result = await ImagePicker.launchCameraAsync({\n allowsEditing: editingAllowed,\n aspect: getValueOrDefault(this.props.aspect, DEFAULT_ASPECT),\n exif: getValueOrDefault(this.props.exif, DEFAULT_EXIF),\n });\n\n if (!result.canceled && !_.isEmpty(result.assets)) {\n this.handleImagePicked(result.assets[0].uri);\n }\n };\n\n openVideoCamera = async () => {\n if (!(await this.askPermissionsAsync())) return;\n\n const result = await ImagePicker.launchCameraAsync({\n allowsEditing: this.isEditingEnabled(),\n mediaTypes: ImagePicker.MediaTypeOptions.Videos,\n });\n\n if (!result.canceled && !_.isEmpty(result.assets)) {\n this.handleImagePicked(result.assets[0].uri);\n }\n };\n\n openLibrary = async () => {\n this.setState(\n {\n showUploadMenu: false,\n },\n () => {\n setTimeout(() => {\n this.setState({\n showPhotos: true,\n selected: [],\n showRemote: true,\n selectedAlbumId: '',\n });\n }, 1000);\n },\n );\n };\n\n openPhotos = async () => {\n if (Platform.OS === 'android') {\n const result = await ImagePicker.launchImageLibraryAsync({\n allowsEditing: this.isEditingEnabled(),\n aspect: getValueOrDefault(this.props.aspect, DEFAULT_ASPECT),\n exif: getValueOrDefault(this.props.exif, DEFAULT_EXIF),\n mediaTypes: this.props.allowVideo ? ImagePicker.MediaTypeOptions.All : ImagePicker.MediaTypeOptions.Images,\n });\n if (!result.cancelled) {\n if (result.assets.length === 1 && result.assets[0].type === 'video') {\n this.handleVideoPicked(result.assets[0].uri);\n } else {\n this.handleMultiImagePicked(result.assets);\n }\n }\n return;\n }\n\n // iOS behaviour\n if (!(await this.askPermissionsAsync())) return;\n\n this.setState(\n {\n showUploadMenu: false,\n },\n () => {\n setTimeout(() => {\n this.setState({\n showPhotos: true,\n selected: [],\n showRemote: false,\n selectedAlbumId: '',\n });\n }, 1000);\n },\n );\n };\n\n hidePhotos = () => {\n this.setState({ showPhotos: false });\n };\n\n openCropper = () => {\n // Switching modals - requires a timeout to ensure the modal is closed before opening the next one\n this.setState(\n {\n showPhotos: false,\n },\n () => {\n setTimeout(() => {\n this.setState({\n showCropper: true,\n });\n }, 1000);\n },\n );\n };\n\n toggleCropper = () => {\n this.setState({ showCropper: !this.state.showCropper });\n };\n\n onSelectAlbum = () => {\n this.setState({ showSelectAlbum: true });\n };\n\n onSelectAlbumClosed = () => {\n this.setState({ showSelectAlbum: false });\n };\n\n onAlbumSelected = selectedAlbumId => {\n this.setState({ showSelectAlbum: false, selectedAlbumId });\n };\n\n onSelectionChange = (selected, videoSelected, onAttach) => {\n this.setState({\n selected,\n selectedType: videoSelected ? 'video' : 'image',\n onAttach,\n });\n };\n\n onSelected = async callback => {\n if (this.isEditingEnabled()) {\n this.openCropper();\n } else {\n const mediaSelected = await callback;\n // console.log('mediaSelected', mediaSelected);\n if (this.state.showRemote) {\n if (this.props.onLibrarySelected) {\n mediaSelected.map(media => {\n this.props.onLibrarySelected(media.uri);\n });\n }\n } else {\n if (mediaSelected[0].mediaType === MediaLibrary.MediaType.video) {\n const uri = mediaSelected[0].localUri || mediaSelected[0].uri;\n this.handleVideoPicked(uri);\n } else {\n this.handleMultiImagePicked(mediaSelected);\n }\n }\n\n this.hidePhotos();\n }\n };\n\n onRemoveImage = uri => {\n const selected = [...this.state.selected];\n const deleteIndex = selected.indexOf(uri);\n selected.splice(deleteIndex, 1);\n this.setState({ selected });\n };\n\n buildOptions = () => {\n const options = [\n {\n text: 'Take photo',\n onPress: this.openCamera,\n },\n ];\n if (this.props.allowVideo)\n options.push({\n text: 'Record video',\n onPress: this.openVideoCamera,\n });\n options.push({\n text: 'Camera Roll',\n onPress: this.openPhotos,\n });\n if (!this.props.hideLibrary)\n options.push({\n text: 'Image Library',\n onPress: this.openLibrary,\n });\n\n return options;\n };\n\n renderSelectionPreview() {\n const { selected, showRemote } = this.state;\n\n return (\n <View>\n <ScrollView horizontal showsHorizontalScrollIndicator={false} contentContainerStyle={styles.selectionPreviewContainer}>\n {selected &&\n selected.map(uri => {\n const imageUri = showRemote ? getThumb300(uri) : uri;\n return (\n <View key={uri} style={styles.previewItemContainer}>\n <ImageBackground style={styles.previewItemImage} source={{ uri: imageUri }} />\n <TouchableOpacity style={styles.previewItemRemoveButton} onPress={() => this.onRemoveImage(uri)}>\n <View style={[styles.previewItemRemoveContainer, { backgroundColor: this.props.colourBrandingMain }]}>\n <Icon name=\"times\" type=\"font-awesome\" iconStyle={styles.previewItemRemoveIcon} />\n </View>\n </TouchableOpacity>\n </View>\n );\n })}\n </ScrollView>\n </View>\n );\n }\n\n renderSelectedAlbum() {\n const { localAlbums, selectedAlbumId, showRemote } = this.state;\n const selectedAlbum = (showRemote ? this.props.imageLibrary : localAlbums).find(album => album.id === selectedAlbumId);\n const selectedAlbumText = selectedAlbum ? selectedAlbum.title : '';\n\n return (\n <TouchableOpacity onPress={this.onSelectAlbum}>\n <View style={styles.selectAlbumButton}>\n <Text style={styles.selectAlbumButtonText}>{selectedAlbumText}</Text>\n <Icon name=\"angle-down\" type=\"font-awesome\" iconStyle={styles.selectAlbumButtonIcon} />\n </View>\n </TouchableOpacity>\n );\n }\n\n renderSelectedComponent = selectedItemNumber => {\n return (\n <View style={styles.selectedItemContainer}>\n <View style={[styles.selectedMarkerContainer, { backgroundColor: this.props.colourBrandingMain }]}>\n {this.props.multiple ? (\n <Text style={styles.selectedItemText}>{selectedItemNumber}</Text>\n ) : (\n <Icon name=\"check\" type=\"font-awesome\" iconStyle={styles.selectedItemIcon} />\n )}\n </View>\n </View>\n );\n };\n\n renderBrowser() {\n const { selected, selectedAlbumId, showRemote } = this.state;\n const { imagesLimit, multiple, allowVideo, imageLibrary } = this.props;\n const width = (SCREEN_WIDTH - 10 * 2) / 4;\n\n return (\n <ImageBrowser\n max={!multiple ? 1 : imagesLimit}\n loadCount={30}\n onChange={this.onSelectionChange}\n renderSelectedComponent={this.renderSelectedComponent}\n callback={this.onSelected}\n selected={selected}\n allowVideo={allowVideo}\n style={styles.browserContainer}\n itemStyle={styles.itemContainer}\n itemWidth={width}\n itemHeight={width}\n album={selectedAlbumId}\n remoteAlbums={showRemote ? imageLibrary : null}\n />\n );\n }\n\n renderAttachButton() {\n const { selected, selectedType } = this.state;\n const canAttach = selected.length > 0 && !_.isEmpty(selectedType);\n const attachText = `Attach ${canAttach ? selected.length : ''} ${canAttach ? selectedType : ''}${selected.length > 1 ? 's' : ''}`;\n\n return (\n <View style={styles.buttonContainer}>\n <InlineButton\n color={canAttach ? this.props.colourBrandingMain : INACTIVE_BUTTON}\n onPress={this.state.onAttach}\n fillTouchable\n large\n disabled={!canAttach}\n >\n {attachText}\n </InlineButton>\n </View>\n );\n }\n\n renderSelectAlbumPopup() {\n const { showSelectAlbum, localAlbums, showRemote } = this.state;\n if (!showSelectAlbum) return null;\n\n return (\n <Modal visible transparent animationType=\"slide\" onRequestClose={this.onSelectAlbumClosed}>\n <View style={styles.selectAlbumModal}>\n <View style={styles.selectAlbumContainer}>\n <View style={styles.selectAlbumTitleContainer}>\n <Text style={styles.selectAlbumTitle}>Select Album</Text>\n </View>\n <ScrollView>\n {(showRemote ? this.props.imageLibrary : localAlbums).map((album, index) => {\n return (\n <TouchableOpacity key={album.id} onPress={() => this.onAlbumSelected(album.id)}>\n <View style={[styles.albumOptionContainer, index === 0 && { borderTopWidth: 0 }]}>\n <Text style={styles.albumOptionText}>{album.title}</Text>\n </View>\n </TouchableOpacity>\n );\n })}\n </ScrollView>\n <TouchableOpacity onPress={this.onSelectAlbumClosed}>\n <View style={[styles.albumOptionContainer, { marginHorizontal: 0 }]}>\n <Text style={[styles.albumOptionText, { color: this.props.colourBrandingMain }]}>Cancel</Text>\n </View>\n </TouchableOpacity>\n </View>\n </View>\n </Modal>\n );\n }\n\n renderPhotos() {\n return (\n <Modal visible transparent animationType=\"slide\" onRequestClose={this.hidePhotos}>\n <Header leftIcon=\"angle-left\" onPressLeft={this.hidePhotos} text={this.props.popupTitle || 'Attach image'} />\n <View style={styles.contentContainer}>\n {this.renderSelectionPreview()}\n {this.renderSelectedAlbum()}\n {this.renderBrowser()}\n </View>\n {this.renderAttachButton()}\n {this.renderSelectAlbumPopup()}\n </Modal>\n );\n }\n\n render() {\n const { warning, showUploadMenu, showPhotos, showCropper, selected } = this.state;\n\n if (warning != null) {\n return (\n <Popup\n title=\"Permissions missing\"\n text={warning}\n options={[\n {\n text: 'Go to settings',\n action: this.goToPermissionSettings.bind(this),\n bold: true,\n },\n {\n text: 'Ignore',\n action: this.closeWarningPopup.bind(this),\n },\n ]}\n />\n );\n }\n\n if (showUploadMenu) {\n const options = this.buildOptions();\n return <PopupMenu onClose={this.hideUploadMenu.bind(this)} options={options} title={this.props.popupTitle} cancelText=\"Cancel\" />;\n }\n\n if (showPhotos) return this.renderPhotos();\n\n if (showCropper) {\n return (\n <ExpoImageManipulator\n photo={{ uri: selected[0] }}\n onToggleModal={this.toggleCropper}\n isVisible={showCropper}\n onPictureChoosed={data => {\n this.handleImagePicked(data.uri);\n }}\n />\n );\n }\n\n return null;\n }\n}\n\nconst styles = StyleSheet.create({\n contentContainer: {\n flex: 1,\n backgroundColor: BOXGREY,\n },\n browserContainer: {\n padding: 10,\n },\n itemContainer: {\n padding: 4,\n },\n selectedItemContainer: {\n flex: 1,\n backgroundColor: '#0008',\n },\n selectedMarkerContainer: {\n position: 'absolute',\n top: 6,\n right: 6,\n width: 20,\n height: 20,\n borderRadius: 10,\n alignItems: 'center',\n justifyContent: 'center',\n },\n selectedItemText: {\n fontFamily: 'sf-semibold',\n fontSize: 12,\n color: '#fff',\n marginBottom: 1,\n },\n selectedItemIcon: {\n fontSize: 12,\n color: '#fff',\n marginBottom: 1,\n },\n buttonContainer: {\n alignItems: 'center',\n justifyContent: 'center',\n height: 60,\n paddingHorizontal: 14,\n backgroundColor: '#fff',\n },\n selectAlbumButton: {\n paddingTop: 13,\n paddingHorizontal: 14,\n flexDirection: 'row',\n alignItems: 'center',\n },\n selectAlbumButtonText: {\n fontFamily: 'sf-medium',\n fontSize: 14,\n color: TEXT_BLUEGREY,\n marginRight: 6,\n },\n selectAlbumButtonIcon: {\n fontSize: 20,\n color: TEXT_BLUEGREY,\n },\n selectAlbumModal: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n top: 0,\n backgroundColor: 'rgba(0,0,0,0.5)',\n zIndex: 1000,\n },\n selectAlbumContainer: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n backgroundColor: '#fff',\n borderTopLeftRadius: 12,\n borderTopRightRadius: 12,\n maxHeight: SCREEN_HEIGHT / 2,\n },\n selectAlbumTitleContainer: {\n padding: 16,\n borderColor: LINEGREY,\n borderBottomWidth: 1,\n },\n selectAlbumTitle: {\n fontFamily: 'sf-semibold',\n fontSize: 16,\n textAlign: 'center',\n color: TEXT_DARK,\n },\n albumOptionContainer: {\n marginHorizontal: 16,\n paddingVertical: 16,\n borderColor: LINEGREY,\n borderTopWidth: 1,\n },\n albumOptionText: {\n fontFamily: 'sf-regular',\n fontSize: 16,\n textAlign: 'center',\n color: TEXT_DARK,\n },\n selectionPreviewContainer: {\n paddingTop: 14,\n paddingRight: 2,\n paddingLeft: 14,\n },\n previewItemContainer: {\n marginRight: 12,\n },\n previewItemImage: {\n width: 50,\n height: 50,\n alignItems: 'center',\n justifyContent: 'center',\n borderRadius: 4,\n overflow: 'hidden',\n },\n previewItemRemoveButton: {\n position: 'absolute',\n top: -8,\n right: -8,\n },\n previewItemRemoveContainer: {\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 10,\n width: 20,\n height: 20,\n borderWidth: 2,\n borderColor: '#fff',\n },\n previewItemRemoveIcon: {\n fontSize: 10,\n color: '#fff',\n marginBottom: 1,\n },\n});\n\nconst mapStateToProps = state => {\n const { user, media } = state;\n const imageLibrary = media.imageLibrary\n .filter(folder => !folder.Public)\n .map(album => {\n return {\n title: album.Name,\n id: album.RowId || '',\n images: album.RowId ? album.Images : media.stockImages,\n };\n });\n\n return {\n user,\n imageLibrary,\n colourBrandingMain: getMainBrandingColourFromState(state),\n };\n};\n\nexport default connect(mapStateToProps, { stockImagesLoaded, imageLibraryLoaded }, null, { forwardRef: true })(ImageUploader);\n"],"mappings":"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","ignoreList":[]}
|
package/dist/module/config.js
CHANGED
|
@@ -16,12 +16,7 @@ const CoreConfig = {
|
|
|
16
16
|
preferredSite: '',
|
|
17
17
|
strings: {},
|
|
18
18
|
newEventDefaults: '',
|
|
19
|
-
defaultAllowComments: true
|
|
20
|
-
AuthStrategy: {
|
|
21
|
-
getAccessToken: async () => null,
|
|
22
|
-
getCurrentUserId: async () => null,
|
|
23
|
-
hasActiveSession: async () => false
|
|
24
|
-
}
|
|
19
|
+
defaultAllowComments: true
|
|
25
20
|
},
|
|
26
21
|
init: (environment, navigation) => {
|
|
27
22
|
CoreConfig.env = environment;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["Services","navigation","CoreConfig","env","baseStage","baseAPIUrl","hasGradientHeader","defaultProfileImage","tinyChatDefault","baseUploadsUrl","allowMediaDownload","allowMediaSharing","awsUploadsBucket","awsStorageBucket","preferredSite","strings","newEventDefaults","defaultAllowComments","
|
|
1
|
+
{"version":3,"names":["Services","navigation","CoreConfig","env","baseStage","baseAPIUrl","hasGradientHeader","defaultProfileImage","tinyChatDefault","baseUploadsUrl","allowMediaDownload","allowMediaSharing","awsUploadsBucket","awsStorageBucket","preferredSite","strings","newEventDefaults","defaultAllowComments","init","environment"],"sources":["config.js"],"sourcesContent":["export const Services = {\n navigation: null,\n};\n\nconst CoreConfig = {\n env: {\n baseStage: '',\n baseAPIUrl: '',\n hasGradientHeader: false,\n defaultProfileImage: '',\n tinyChatDefault: '',\n baseUploadsUrl: '',\n allowMediaDownload: false,\n allowMediaSharing: false,\n awsUploadsBucket: '',\n awsStorageBucket: '',\n preferredSite: '',\n strings: {},\n newEventDefaults: '',\n defaultAllowComments: true,\n },\n init: (environment, navigation) => {\n CoreConfig.env = environment;\n Services.navigation = navigation;\n },\n};\nexport default CoreConfig;\n"],"mappings":"AAAA,OAAO,MAAMA,QAAQ,GAAG;EACtBC,UAAU,EAAE;AACd,CAAC;AAED,MAAMC,UAAU,GAAG;EACjBC,GAAG,EAAE;IACHC,SAAS,EAAE,EAAE;IACbC,UAAU,EAAE,EAAE;IACdC,iBAAiB,EAAE,KAAK;IACxBC,mBAAmB,EAAE,EAAE;IACvBC,eAAe,EAAE,EAAE;IACnBC,cAAc,EAAE,EAAE;IAClBC,kBAAkB,EAAE,KAAK;IACzBC,iBAAiB,EAAE,KAAK;IACxBC,gBAAgB,EAAE,EAAE;IACpBC,gBAAgB,EAAE,EAAE;IACpBC,aAAa,EAAE,EAAE;IACjBC,OAAO,EAAE,CAAC,CAAC;IACXC,gBAAgB,EAAE,EAAE;IACpBC,oBAAoB,EAAE;EACxB,CAAC;EACDC,IAAI,EAAEA,CAACC,WAAW,EAAElB,UAAU,KAAK;IACjCC,UAAU,CAACC,GAAG,GAAGgB,WAAW;IAC5BnB,QAAQ,CAACC,UAAU,GAAGA,UAAU;EAClC;AACF,CAAC;AACD,eAAeC,UAAU","ignoreList":[]}
|
package/dist/module/session.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import _ from 'lodash';
|
|
2
2
|
import axios from 'axios';
|
|
3
3
|
import { Auth } from 'aws-amplify';
|
|
4
|
-
import Config from './config';
|
|
5
4
|
export const getSessionTokenAWS = async prefix => {
|
|
6
|
-
const
|
|
5
|
+
const data = await Auth.currentSession();
|
|
6
|
+
const token = data.accessToken.jwtToken;
|
|
7
7
|
if (_.isUndefined(prefix)) return token;
|
|
8
8
|
return `${prefix} ${token}`;
|
|
9
9
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_","axios","Auth","
|
|
1
|
+
{"version":3,"names":["_","axios","Auth","getSessionTokenAWS","prefix","data","currentSession","token","accessToken","jwtToken","isUndefined","getSessionUidAWS","Promise","resolve","reject","then","payload","username","catch","err","console","log","authedFunction","request","authkey","headers","getApiError","error","__DEV__","errorData","response","e"],"sources":["session.js"],"sourcesContent":["import _ from 'lodash';\nimport axios from 'axios';\nimport { Auth } from 'aws-amplify';\n\nexport const getSessionTokenAWS = async prefix => {\n const data = await Auth.currentSession();\n const token = data.accessToken.jwtToken;\n if (_.isUndefined(prefix)) return token;\n return `${prefix} ${token}`;\n};\n\n// export const getRefreshTokenAWS = async () => {\n// const data = await Auth.currentSession();\n// return data.getRefreshToken().token;\n// };\n\nexport const getSessionUidAWS = () => {\n return new Promise((resolve, reject) => {\n Auth.currentSession()\n .then(data => {\n resolve(data.accessToken.payload.username);\n })\n .catch(err => {\n console.log('getSessionUidAWS error', err);\n reject(err);\n });\n });\n};\n\nexport const authedFunction = async request => {\n const authkey = await getSessionTokenAWS();\n if (!request.headers) request.headers = {};\n request.headers.authkey = authkey;\n\n return axios(request);\n};\n\n// export const LogoutAWS = () => {\n// return new Promise((resolve, reject) => {\n// Auth.signOut()\n// .then(() => {\n// resolve();\n// })\n// .catch(err => {\n// reject(err);\n// });\n// });\n// };\n\n// export const isTheBest = auth => {\n// return auth && auth.site === 'plussSpace' && auth.type === 'master';\n// };\n\nexport const getApiError = error => {\n if (!__DEV__) return error;\n try {\n const errorData = error.response.data;\n return errorData || error;\n } catch (e) {\n return error;\n }\n};\n"],"mappings":"AAAA,OAAOA,CAAC,MAAM,QAAQ;AACtB,OAAOC,KAAK,MAAM,OAAO;AACzB,SAASC,IAAI,QAAQ,aAAa;AAElC,OAAO,MAAMC,kBAAkB,GAAG,MAAMC,MAAM,IAAI;EAChD,MAAMC,IAAI,GAAG,MAAMH,IAAI,CAACI,cAAc,CAAC,CAAC;EACxC,MAAMC,KAAK,GAAGF,IAAI,CAACG,WAAW,CAACC,QAAQ;EACvC,IAAIT,CAAC,CAACU,WAAW,CAACN,MAAM,CAAC,EAAE,OAAOG,KAAK;EACvC,OAAO,GAAGH,MAAM,IAAIG,KAAK,EAAE;AAC7B,CAAC;;AAED;AACA;AACA;AACA;;AAEA,OAAO,MAAMI,gBAAgB,GAAGA,CAAA,KAAM;EACpC,OAAO,IAAIC,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;IACtCZ,IAAI,CAACI,cAAc,CAAC,CAAC,CAClBS,IAAI,CAACV,IAAI,IAAI;MACZQ,OAAO,CAACR,IAAI,CAACG,WAAW,CAACQ,OAAO,CAACC,QAAQ,CAAC;IAC5C,CAAC,CAAC,CACDC,KAAK,CAACC,GAAG,IAAI;MACZC,OAAO,CAACC,GAAG,CAAC,wBAAwB,EAAEF,GAAG,CAAC;MAC1CL,MAAM,CAACK,GAAG,CAAC;IACb,CAAC,CAAC;EACN,CAAC,CAAC;AACJ,CAAC;AAED,OAAO,MAAMG,cAAc,GAAG,MAAMC,OAAO,IAAI;EAC7C,MAAMC,OAAO,GAAG,MAAMrB,kBAAkB,CAAC,CAAC;EAC1C,IAAI,CAACoB,OAAO,CAACE,OAAO,EAAEF,OAAO,CAACE,OAAO,GAAG,CAAC,CAAC;EAC1CF,OAAO,CAACE,OAAO,CAACD,OAAO,GAAGA,OAAO;EAEjC,OAAOvB,KAAK,CAACsB,OAAO,CAAC;AACvB,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,OAAO,MAAMG,WAAW,GAAGC,KAAK,IAAI;EAClC,IAAI,CAACC,OAAO,EAAE,OAAOD,KAAK;EAC1B,IAAI;IACF,MAAME,SAAS,GAAGF,KAAK,CAACG,QAAQ,CAACzB,IAAI;IACrC,OAAOwB,SAAS,IAAIF,KAAK;EAC3B,CAAC,CAAC,OAAOI,CAAC,EAAE;IACV,OAAOJ,KAAK;EACd;AACF,CAAC","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@plusscommunities/pluss-core-app",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "8.0.0",
|
|
4
4
|
"description": "Core extension package for Pluss Communities platform",
|
|
5
5
|
"main": "dist/module/index.js",
|
|
6
6
|
"module": "dist/module/index.js",
|
|
@@ -15,9 +15,6 @@
|
|
|
15
15
|
"patch": "npm version patch",
|
|
16
16
|
"betaupload": "npm run build && npm publish --access public --tag beta",
|
|
17
17
|
"betaupload:p": "npm run betapatch && npm run betaupload",
|
|
18
|
-
"authpatch": "npm version prepatch --preid=auth",
|
|
19
|
-
"authupload": "npm run build && npm publish --access public --tag auth",
|
|
20
|
-
"authupload:p": "npm run authpatch && npm run authupload",
|
|
21
18
|
"upload": "npm run build && npm publish --access public",
|
|
22
19
|
"upload:p": "npm run patch && npm run upload"
|
|
23
20
|
},
|
|
@@ -25,30 +22,30 @@
|
|
|
25
22
|
"license": "ISC",
|
|
26
23
|
"dependencies": {},
|
|
27
24
|
"peerDependencies": {
|
|
28
|
-
"@expo/vector-icons": "^
|
|
29
|
-
"@react-native-async-storage/async-storage": "^
|
|
25
|
+
"@expo/vector-icons": "^15.0.3",
|
|
26
|
+
"@react-native-async-storage/async-storage": "^2.2.0",
|
|
30
27
|
"aws-amplify": "^4.3.11",
|
|
31
28
|
"aws-amplify-react-native": "^6.0.2",
|
|
32
29
|
"axios": "^1.6.8",
|
|
33
30
|
"deprecated-react-native-prop-types": "^4.1.0",
|
|
34
|
-
"expo-av": "~
|
|
35
|
-
"expo-calendar": "~
|
|
36
|
-
"expo-constants": "~
|
|
37
|
-
"expo-file-system": "~
|
|
38
|
-
"expo-image-manipulator": "~
|
|
39
|
-
"expo-image-picker": "~
|
|
40
|
-
"expo-linear-gradient": "~
|
|
41
|
-
"expo-media-library": "~
|
|
42
|
-
"expo-screen-orientation": "~
|
|
43
|
-
"expo-sharing": "~
|
|
31
|
+
"expo-av": "~16.0.7",
|
|
32
|
+
"expo-calendar": "~15.0.7",
|
|
33
|
+
"expo-constants": "~18.0.10",
|
|
34
|
+
"expo-file-system": "~19.0.17",
|
|
35
|
+
"expo-image-manipulator": "~14.0.7",
|
|
36
|
+
"expo-image-picker": "~17.0.8",
|
|
37
|
+
"expo-linear-gradient": "~15.0.7",
|
|
38
|
+
"expo-media-library": "~18.2.0",
|
|
39
|
+
"expo-screen-orientation": "~9.0.7",
|
|
40
|
+
"expo-sharing": "~14.0.7",
|
|
44
41
|
"expo-video-player": "^1.6.0",
|
|
45
42
|
"js-cookie": "^2.2.1",
|
|
46
43
|
"lodash": "^4.17.4",
|
|
47
44
|
"mime-types": "^2.1.24",
|
|
48
45
|
"moment": "^2.30.1",
|
|
49
|
-
"react": "
|
|
50
|
-
"react-native": "0.
|
|
51
|
-
"react-native-auto-height-image": "3.1.3",
|
|
46
|
+
"react": "^19.1.0",
|
|
47
|
+
"react-native": "^0.81.5",
|
|
48
|
+
"react-native-auto-height-image": "^3.1.3",
|
|
52
49
|
"react-native-calendars": "^1.1309.1",
|
|
53
50
|
"@rneui/base": "^4.0.0-rc.8",
|
|
54
51
|
"@rneui/themed": "^4.0.0-rc.8",
|
|
@@ -56,7 +53,7 @@
|
|
|
56
53
|
"react-native-image-zoom-viewer": "^3.0.1",
|
|
57
54
|
"react-native-iphone-x-helper": "^1.3.1",
|
|
58
55
|
"react-native-vimeo-iframe": "^1.0.4",
|
|
59
|
-
"react-native-webview": "13.
|
|
56
|
+
"react-native-webview": "^13.15.0",
|
|
60
57
|
"react-native-youtube-iframe": "^2.2.1",
|
|
61
58
|
"react-redux": "^7.2.6"
|
|
62
59
|
},
|
package/src/apis/fileActions.js
CHANGED
|
@@ -1,34 +1,41 @@
|
|
|
1
|
-
import
|
|
1
|
+
import mime from 'mime-types';
|
|
2
|
+
import { Storage } from 'aws-amplify';
|
|
2
3
|
import { getUrl, generateImageName, randomString } from '../helper';
|
|
3
4
|
import { authedFunction } from '../session';
|
|
5
|
+
import Config from '../config';
|
|
4
6
|
|
|
5
7
|
export const fileActions = {
|
|
6
|
-
getPresignedUrl: async (filename, contentType) => {
|
|
7
|
-
// const newFilename = filename.replace(/[^a-z0-9+.]+/gi, '').toLowerCase();
|
|
8
|
-
const signedUrlRes = await authedFunction({
|
|
9
|
-
method: 'GET',
|
|
10
|
-
url: getUrl('media', 'get/presignedurl', { filename, contentType }),
|
|
11
|
-
});
|
|
12
|
-
return signedUrlRes.data;
|
|
13
|
-
},
|
|
14
8
|
getUploadUrl: (userId, fileName) => {
|
|
15
9
|
const newFilename = fileName.replace(/[^a-z0-9+.]+/gi, '').toLowerCase();
|
|
16
10
|
return `uploads/users/${userId}/public/${randomString()}/${newFilename}`;
|
|
17
11
|
},
|
|
18
|
-
uploadUserMediaWithProgress: async (
|
|
19
|
-
|
|
12
|
+
uploadUserMediaWithProgress: async (imageUri, url, progressCallback = null) => {
|
|
13
|
+
const blob = await fileActions.imageToBlob(imageUri);
|
|
14
|
+
return fileActions.uploadBlobAWS(Config.env.awsUploadsBucket, url, blob, '', progressCallback);
|
|
20
15
|
},
|
|
16
|
+
// uploadUserMedia: async (userId, image, fileName) => {
|
|
17
|
+
// const blob = await fileActions.imageToBlob(image.uri);
|
|
18
|
+
// const url = fileActions.getUploadUrl(userId, fileName);
|
|
19
|
+
// return fileActions.uploadBlobAWS(Config.env.awsUploadsBucket, url, blob);
|
|
20
|
+
// },
|
|
21
|
+
// uploadSignatureImage: async (image, name) => {
|
|
22
|
+
// const blob = await fileActions.imageToBlob(image);
|
|
23
|
+
// const newImageName = generateImageName(name, 'signature.png');
|
|
24
|
+
// return fileActions.uploadBlobAWS(Config.env.awsStorageBucket, newImageName, blob, 'images/');
|
|
25
|
+
// },
|
|
21
26
|
imageToBlob: async imageUri => {
|
|
22
27
|
const response = await fetch(imageUri);
|
|
23
28
|
return response.blob();
|
|
24
29
|
},
|
|
25
|
-
uploadBlobAWS:
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
30
|
+
uploadBlobAWS: (bucket, uri, blob, prefix = '', progressCallback = null) => {
|
|
31
|
+
const imageName = prefix ? uri.replace(/^.*[\\/]/, '') : uri;
|
|
32
|
+
const fileType = mime.lookup(uri);
|
|
33
|
+
const access = {
|
|
34
|
+
level: 'public',
|
|
35
|
+
bucket,
|
|
36
|
+
contentType: fileType,
|
|
37
|
+
customPrefix: { public: '' },
|
|
38
|
+
progressCallback: progress =>
|
|
32
39
|
progressCallback &&
|
|
33
40
|
progressCallback({
|
|
34
41
|
uri,
|
|
@@ -36,7 +43,8 @@ export const fileActions = {
|
|
|
36
43
|
total: progress.total,
|
|
37
44
|
percentage: `${Math.floor((progress.loaded / progress.total) * 100)}%`,
|
|
38
45
|
}),
|
|
39
|
-
}
|
|
46
|
+
};
|
|
47
|
+
return Storage.put(`${prefix}${imageName}`, blob, access);
|
|
40
48
|
},
|
|
41
49
|
getStockPhotos: async () => {
|
|
42
50
|
const response = await authedFunction({
|
|
@@ -142,25 +142,23 @@ class ImageUploader extends Component {
|
|
|
142
142
|
let uploadUri;
|
|
143
143
|
try {
|
|
144
144
|
const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;
|
|
145
|
+
uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
|
|
145
146
|
|
|
147
|
+
this.props.onUploadStarted(uploadUri, imageUri);
|
|
146
148
|
this.hideUploadMenu();
|
|
147
149
|
|
|
148
150
|
const resized = await this.resizeImageAsync(imageUri);
|
|
149
|
-
const blob = await fileActions.imageToBlob(resized.uri);
|
|
150
|
-
const presignedUriRes = await fileActions.getPresignedUrl(_.last(resized.uri.split('/')), blob.type);
|
|
151
|
-
uploadUri = presignedUriRes.key;
|
|
152
|
-
this.props.onUploadStarted(uploadUri, imageUri);
|
|
153
151
|
if (this.props.onlySelectImage) {
|
|
154
152
|
this.props.onImageSelected(resized, fileName);
|
|
155
153
|
return;
|
|
156
154
|
}
|
|
157
155
|
|
|
158
|
-
const
|
|
156
|
+
const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {
|
|
159
157
|
if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
|
|
160
158
|
});
|
|
161
159
|
|
|
162
|
-
this.props.onUploadSuccess(Config.env.baseUploadsUrl +
|
|
163
|
-
console.log('upload success', Config.env.baseUploadsUrl +
|
|
160
|
+
this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
|
|
161
|
+
console.log('upload success', Config.env.baseUploadsUrl + res.key);
|
|
164
162
|
} catch (e) {
|
|
165
163
|
console.log('handleImagePicked error', e);
|
|
166
164
|
this.props.onUploadFailed(uploadUri);
|
|
@@ -172,6 +170,7 @@ class ImageUploader extends Component {
|
|
|
172
170
|
const imagesUploaded = imagesSelected.map(image => {
|
|
173
171
|
const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;
|
|
174
172
|
const uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
|
|
173
|
+
if (!this.props.onlySelectImage) this.props.onUploadStarted(uploadUri, image.uri);
|
|
175
174
|
return { imageUri: image.uri, uploadUri, fileName };
|
|
176
175
|
});
|
|
177
176
|
this.hideUploadMenu();
|
|
@@ -182,21 +181,16 @@ class ImageUploader extends Component {
|
|
|
182
181
|
const { imageUri, uploadUri, fileName } = image;
|
|
183
182
|
try {
|
|
184
183
|
const resized = await this.resizeImageAsync(imageUri);
|
|
185
|
-
const blob = await fileActions.imageToBlob(resized.uri);
|
|
186
184
|
if (this.props.onlySelectImage) {
|
|
187
185
|
this.props.onImageSelected(resized, fileName);
|
|
188
186
|
return;
|
|
189
187
|
}
|
|
190
|
-
const presignedUriRes = await fileActions.getPresignedUrl(_.last(resized.uri.split('/')), blob.type);
|
|
191
|
-
const uploadUri = presignedUriRes.key;
|
|
192
|
-
if (!this.props.onlySelectImage) this.props.onUploadStarted(uploadUri, imageUri);
|
|
193
188
|
|
|
194
|
-
const
|
|
189
|
+
const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {
|
|
195
190
|
if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
|
|
196
191
|
});
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
console.log('upload success', Config.env.baseUploadsUrl + uploadUri);
|
|
192
|
+
this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
|
|
193
|
+
console.log('upload success', Config.env.baseUploadsUrl + res.key);
|
|
200
194
|
} catch (e) {
|
|
201
195
|
console.log('handleMultiImagePicked error', e);
|
|
202
196
|
this.props.onUploadFailed(uploadUri);
|
|
@@ -209,19 +203,17 @@ class ImageUploader extends Component {
|
|
|
209
203
|
try {
|
|
210
204
|
const fileType = uri.substring(uri.lastIndexOf('.') + 1);
|
|
211
205
|
const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_VIDEO_NAME)}.${fileType}`;
|
|
212
|
-
|
|
213
|
-
const presignedUriRes = await fileActions.getPresignedUrl(fileName, blob.type);
|
|
214
|
-
uploadUri = presignedUriRes.key;
|
|
206
|
+
uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
|
|
215
207
|
|
|
216
208
|
this.props.onUploadStarted(uploadUri, uri);
|
|
217
209
|
this.hideUploadMenu();
|
|
218
210
|
|
|
219
|
-
const
|
|
211
|
+
const res = await fileActions.uploadUserMediaWithProgress(uri, uploadUri, progress => {
|
|
220
212
|
if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
|
|
221
213
|
});
|
|
222
214
|
|
|
223
|
-
this.props.onUploadSuccess(Config.env.baseUploadsUrl +
|
|
224
|
-
console.log('upload success', Config.env.baseUploadsUrl +
|
|
215
|
+
this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
|
|
216
|
+
console.log('upload success', Config.env.baseUploadsUrl + res.key);
|
|
225
217
|
} catch (e) {
|
|
226
218
|
console.log('handleVideoPicked error', e);
|
|
227
219
|
this.props.onUploadFailed(uploadUri);
|
|
@@ -274,7 +266,6 @@ class ImageUploader extends Component {
|
|
|
274
266
|
};
|
|
275
267
|
|
|
276
268
|
isEditingEnabled = () => {
|
|
277
|
-
return false;
|
|
278
269
|
return !this.props.multiple && !this.props.allowVideo && getValueOrDefault(this.props.allowsEditing, DEFAULT_ALLOWS_EDITING);
|
|
279
270
|
};
|
|
280
271
|
|
|
@@ -427,7 +418,6 @@ class ImageUploader extends Component {
|
|
|
427
418
|
} else {
|
|
428
419
|
if (mediaSelected[0].mediaType === MediaLibrary.MediaType.video) {
|
|
429
420
|
const uri = mediaSelected[0].localUri || mediaSelected[0].uri;
|
|
430
|
-
console.log('picked a video');
|
|
431
421
|
this.handleVideoPicked(uri);
|
|
432
422
|
} else {
|
|
433
423
|
this.handleMultiImagePicked(mediaSelected);
|
package/src/config.js
CHANGED
|
@@ -18,11 +18,6 @@ const CoreConfig = {
|
|
|
18
18
|
strings: {},
|
|
19
19
|
newEventDefaults: '',
|
|
20
20
|
defaultAllowComments: true,
|
|
21
|
-
AuthStrategy: {
|
|
22
|
-
getAccessToken: async () => null,
|
|
23
|
-
getCurrentUserId: async () => null,
|
|
24
|
-
hasActiveSession: async () => false,
|
|
25
|
-
},
|
|
26
21
|
},
|
|
27
22
|
init: (environment, navigation) => {
|
|
28
23
|
CoreConfig.env = environment;
|
package/src/session.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import _ from 'lodash';
|
|
2
2
|
import axios from 'axios';
|
|
3
3
|
import { Auth } from 'aws-amplify';
|
|
4
|
-
import Config from './config';
|
|
5
4
|
|
|
6
5
|
export const getSessionTokenAWS = async prefix => {
|
|
7
|
-
const
|
|
6
|
+
const data = await Auth.currentSession();
|
|
7
|
+
const token = data.accessToken.jwtToken;
|
|
8
8
|
if (_.isUndefined(prefix)) return token;
|
|
9
9
|
return `${prefix} ${token}`;
|
|
10
10
|
};
|