@plusscommunities/pluss-core-app 7.0.0-beta.2 → 7.0.1-auth.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.
@@ -1,49 +1,42 @@
1
- import mime from 'mime-types';
2
- import { Storage } from 'aws-amplify';
1
+ import Axios from 'axios';
3
2
  import { getUrl, generateImageName, randomString } from '../helper';
4
3
  import { authedFunction } from '../session';
5
- import Config from '../config';
6
4
  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
+ },
7
16
  getUploadUrl: (userId, fileName) => {
8
17
  const newFilename = fileName.replace(/[^a-z0-9+.]+/gi, '').toLowerCase();
9
18
  return `uploads/users/${userId}/public/${randomString()}/${newFilename}`;
10
19
  },
11
- uploadUserMediaWithProgress: async (imageUri, url, progressCallback = null) => {
12
- const blob = await fileActions.imageToBlob(imageUri);
13
- return fileActions.uploadBlobAWS(Config.env.awsUploadsBucket, url, blob, '', progressCallback);
20
+ uploadUserMediaWithProgress: async (blob, url, progressCallback = null) => {
21
+ return fileActions.uploadBlobAWS(url, blob, progressCallback);
14
22
  },
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
- // },
25
23
  imageToBlob: async imageUri => {
26
24
  const response = await fetch(imageUri);
27
25
  return response.blob();
28
26
  },
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: ''
27
+ uploadBlobAWS: async (uri, blob, progressCallback = null) => {
28
+ return Axios.put(uri, blob, {
29
+ headers: {
30
+ 'Content-Type': blob.type
38
31
  },
39
- progressCallback: progress => progressCallback && progressCallback({
32
+ transformRequest: d => d,
33
+ onUploadProgress: progress => progressCallback && progressCallback({
40
34
  uri,
41
35
  loaded: progress.loaded,
42
36
  total: progress.total,
43
37
  percentage: `${Math.floor(progress.loaded / progress.total * 100)}%`
44
38
  })
45
- };
46
- return Storage.put(`${prefix}${imageName}`, blob, access);
39
+ });
47
40
  },
48
41
  getStockPhotos: async () => {
49
42
  const response = await authedFunction({
@@ -1 +1 @@
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":[]}
1
+ {"version":3,"names":["Axios","getUrl","generateImageName","randomString","authedFunction","fileActions","getPresignedUrl","filename","contentType","signedUrlRes","method","url","data","getUploadUrl","userId","fileName","newFilename","replace","toLowerCase","uploadUserMediaWithProgress","blob","progressCallback","uploadBlobAWS","imageToBlob","imageUri","response","fetch","uri","put","headers","type","transformRequest","d","onUploadProgress","progress","loaded","total","percentage","Math","floor","getStockPhotos","images","map","image","getMediaFolders","site","query"],"sources":["fileActions.js"],"sourcesContent":["import Axios from 'axios';\nimport { getUrl, generateImageName, randomString } from '../helper';\nimport { authedFunction } from '../session';\n\nexport const fileActions = {\n getPresignedUrl: async (filename, contentType) => {\n // const newFilename = filename.replace(/[^a-z0-9+.]+/gi, '').toLowerCase();\n const signedUrlRes = await authedFunction({\n method: 'GET',\n url: getUrl('media', 'get/presignedurl', { filename, contentType }),\n });\n return signedUrlRes.data;\n },\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 (blob, url, progressCallback = null) => {\n return fileActions.uploadBlobAWS(url, blob, progressCallback);\n },\n imageToBlob: async imageUri => {\n const response = await fetch(imageUri);\n return response.blob();\n },\n uploadBlobAWS: async (uri, blob, progressCallback = null) => {\n return Axios.put(uri, blob, {\n headers: {\n 'Content-Type': blob.type,\n },\n transformRequest: d => d,\n onUploadProgress: 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 },\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":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,MAAM,EAAEC,iBAAiB,EAAEC,YAAY,QAAQ,WAAW;AACnE,SAASC,cAAc,QAAQ,YAAY;AAE3C,OAAO,MAAMC,WAAW,GAAG;EACzBC,eAAe,EAAE,MAAAA,CAAOC,QAAQ,EAAEC,WAAW,KAAK;IAChD;IACA,MAAMC,YAAY,GAAG,MAAML,cAAc,CAAC;MACxCM,MAAM,EAAE,KAAK;MACbC,GAAG,EAAEV,MAAM,CAAC,OAAO,EAAE,kBAAkB,EAAE;QAAEM,QAAQ;QAAEC;MAAY,CAAC;IACpE,CAAC,CAAC;IACF,OAAOC,YAAY,CAACG,IAAI;EAC1B,CAAC;EACDC,YAAY,EAAEA,CAACC,MAAM,EAAEC,QAAQ,KAAK;IAClC,MAAMC,WAAW,GAAGD,QAAQ,CAACE,OAAO,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAACC,WAAW,CAAC,CAAC;IACxE,OAAO,iBAAiBJ,MAAM,WAAWX,YAAY,CAAC,CAAC,IAAIa,WAAW,EAAE;EAC1E,CAAC;EACDG,2BAA2B,EAAE,MAAAA,CAAOC,IAAI,EAAET,GAAG,EAAEU,gBAAgB,GAAG,IAAI,KAAK;IACzE,OAAOhB,WAAW,CAACiB,aAAa,CAACX,GAAG,EAAES,IAAI,EAAEC,gBAAgB,CAAC;EAC/D,CAAC;EACDE,WAAW,EAAE,MAAMC,QAAQ,IAAI;IAC7B,MAAMC,QAAQ,GAAG,MAAMC,KAAK,CAACF,QAAQ,CAAC;IACtC,OAAOC,QAAQ,CAACL,IAAI,CAAC,CAAC;EACxB,CAAC;EACDE,aAAa,EAAE,MAAAA,CAAOK,GAAG,EAAEP,IAAI,EAAEC,gBAAgB,GAAG,IAAI,KAAK;IAC3D,OAAOrB,KAAK,CAAC4B,GAAG,CAACD,GAAG,EAAEP,IAAI,EAAE;MAC1BS,OAAO,EAAE;QACP,cAAc,EAAET,IAAI,CAACU;MACvB,CAAC;MACDC,gBAAgB,EAAEC,CAAC,IAAIA,CAAC;MACxBC,gBAAgB,EAAEC,QAAQ,IACxBb,gBAAgB,IAChBA,gBAAgB,CAAC;QACfM,GAAG;QACHQ,MAAM,EAAED,QAAQ,CAACC,MAAM;QACvBC,KAAK,EAAEF,QAAQ,CAACE,KAAK;QACrBC,UAAU,EAAE,GAAGC,IAAI,CAACC,KAAK,CAAEL,QAAQ,CAACC,MAAM,GAAGD,QAAQ,CAACE,KAAK,GAAI,GAAG,CAAC;MACrE,CAAC;IACL,CAAC,CAAC;EACJ,CAAC;EACDI,cAAc,EAAE,MAAAA,CAAA,KAAY;IAC1B,MAAMf,QAAQ,GAAG,MAAMrB,cAAc,CAAC;MACpCM,MAAM,EAAE,KAAK;MACbC,GAAG,EAAE;IACP,CAAC,CAAC;IACF;IACA,MAAM8B,MAAM,GAAGhB,QAAQ,CAACb,IAAI,CAAC8B,GAAG,CAACC,KAAK,IAAI;MACxC,OAAO;QAAEhB,GAAG,EAAEgB;MAAM,CAAC;IACvB,CAAC,CAAC;IACF,OAAOF,MAAM;EACf,CAAC;EACDG,eAAe,EAAEC,IAAI,IAAI;IACvB,MAAMC,KAAK,GAAG;MAAED;IAAK,CAAC;IACtB,OAAOzC,cAAc,CAAC;MACpBM,MAAM,EAAE,KAAK;MACbC,GAAG,EAAEV,MAAM,CAAC,OAAO,EAAE,SAAS,EAAE6C,KAAK;IACvC,CAAC,CAAC;EACJ;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACF,CAAC","ignoreList":[]}
@@ -38,20 +38,8 @@ class ImageUploader extends Component {
38
38
  constructor(props) {
39
39
  super(props);
40
40
  _defineProperty(this, "loadLocalAlbums", async () => {
41
- const {
42
- status: existingStatus
43
- } = await MediaLibrary.getPermissionsAsync();
44
- let status = existingStatus;
45
- if (status !== 'granted') {
46
- const {
47
- status: newStatus
48
- } = await MediaLibrary.requestPermissionsAsync();
49
- status = newStatus;
50
- }
51
- if (status !== 'granted') {
52
- console.warn('MediaLibrary permission not granted');
53
- return;
54
- }
41
+ const hasPermission = await MediaLibrary.getPermissionsAsync();
42
+ if (!hasPermission.granted) return;
55
43
  this.setState({
56
44
  loadingLocalFolders: true
57
45
  }, async () => {
@@ -120,19 +108,21 @@ class ImageUploader extends Component {
120
108
  let uploadUri;
121
109
  try {
122
110
  const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;
123
- uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
124
- this.props.onUploadStarted(uploadUri, imageUri);
125
111
  this.hideUploadMenu();
126
112
  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);
127
117
  if (this.props.onlySelectImage) {
128
118
  this.props.onImageSelected(resized, fileName);
129
119
  return;
130
120
  }
131
- const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {
121
+ const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {
132
122
  if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
133
123
  });
134
- this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
135
- console.log('upload success', Config.env.baseUploadsUrl + res.key);
124
+ this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);
125
+ console.log('upload success', Config.env.baseUploadsUrl + uploadUri);
136
126
  } catch (e) {
137
127
  console.log('handleImagePicked error', e);
138
128
  this.props.onUploadFailed(uploadUri);
@@ -143,7 +133,6 @@ class ImageUploader extends Component {
143
133
  const imagesUploaded = imagesSelected.map(image => {
144
134
  const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;
145
135
  const uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
146
- if (!this.props.onlySelectImage) this.props.onUploadStarted(uploadUri, image.uri);
147
136
  return {
148
137
  imageUri: image.uri,
149
138
  uploadUri,
@@ -162,15 +151,19 @@ class ImageUploader extends Component {
162
151
  } = image;
163
152
  try {
164
153
  const resized = await this.resizeImageAsync(imageUri);
154
+ const blob = await fileActions.imageToBlob(resized.uri);
165
155
  if (this.props.onlySelectImage) {
166
156
  this.props.onImageSelected(resized, fileName);
167
157
  return;
168
158
  }
169
- const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {
159
+ const presignedUriRes = await fileActions.getPresignedUrl(_.last(resized.uri.split('/')), blob.type);
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 => {
170
163
  if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
171
164
  });
172
- this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
173
- console.log('upload success', Config.env.baseUploadsUrl + res.key);
165
+ this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);
166
+ console.log('upload success', Config.env.baseUploadsUrl + uploadUri);
174
167
  } catch (e) {
175
168
  console.log('handleMultiImagePicked error', e);
176
169
  this.props.onUploadFailed(uploadUri);
@@ -182,14 +175,16 @@ class ImageUploader extends Component {
182
175
  try {
183
176
  const fileType = uri.substring(uri.lastIndexOf('.') + 1);
184
177
  const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_VIDEO_NAME)}.${fileType}`;
185
- uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
178
+ const blob = await fileActions.imageToBlob(uri);
179
+ const presignedUriRes = await fileActions.getPresignedUrl(fileName, blob.type);
180
+ uploadUri = presignedUriRes.key;
186
181
  this.props.onUploadStarted(uploadUri, uri);
187
182
  this.hideUploadMenu();
188
- const res = await fileActions.uploadUserMediaWithProgress(uri, uploadUri, progress => {
183
+ const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {
189
184
  if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
190
185
  });
191
- this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
192
- console.log('upload success', Config.env.baseUploadsUrl + res.key);
186
+ this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);
187
+ console.log('upload success', Config.env.baseUploadsUrl + uploadUri);
193
188
  } catch (e) {
194
189
  console.log('handleVideoPicked error', e);
195
190
  this.props.onUploadFailed(uploadUri);
@@ -207,6 +202,7 @@ class ImageUploader extends Component {
207
202
  return true;
208
203
  });
209
204
  _defineProperty(this, "isEditingEnabled", () => {
205
+ return false;
210
206
  return !this.props.multiple && !this.props.allowVideo && getValueOrDefault(this.props.allowsEditing, DEFAULT_ALLOWS_EDITING);
211
207
  });
212
208
  _defineProperty(this, "openCamera", async () => {
@@ -236,11 +232,16 @@ class ImageUploader extends Component {
236
232
  });
237
233
  _defineProperty(this, "openLibrary", async () => {
238
234
  this.setState({
239
- showUploadMenu: false,
240
- showPhotos: true,
241
- selected: [],
242
- showRemote: true,
243
- selectedAlbumId: ''
235
+ showUploadMenu: false
236
+ }, () => {
237
+ setTimeout(() => {
238
+ this.setState({
239
+ showPhotos: true,
240
+ selected: [],
241
+ showRemote: true,
242
+ selectedAlbumId: ''
243
+ });
244
+ }, 1000);
244
245
  });
245
246
  });
246
247
  _defineProperty(this, "openPhotos", async () => {
@@ -264,11 +265,16 @@ class ImageUploader extends Component {
264
265
  // iOS behaviour
265
266
  if (!(await this.askPermissionsAsync())) return;
266
267
  this.setState({
267
- showUploadMenu: false,
268
- showPhotos: true,
269
- selected: [],
270
- showRemote: false,
271
- selectedAlbumId: ''
268
+ showUploadMenu: false
269
+ }, () => {
270
+ setTimeout(() => {
271
+ this.setState({
272
+ showPhotos: true,
273
+ selected: [],
274
+ showRemote: false,
275
+ selectedAlbumId: ''
276
+ });
277
+ }, 1000);
272
278
  });
273
279
  });
274
280
  _defineProperty(this, "hidePhotos", () => {
@@ -325,6 +331,7 @@ class ImageUploader extends Component {
325
331
  } else {
326
332
  if (mediaSelected[0].mediaType === MediaLibrary.MediaType.video) {
327
333
  const uri = mediaSelected[0].localUri || mediaSelected[0].uri;
334
+ console.log('picked a video');
328
335
  this.handleVideoPicked(uri);
329
336
  } else {
330
337
  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","status","existingStatus","getPermissionsAsync","newStatus","requestPermissionsAsync","console","warn","setState","loadingLocalFolders","localAlbums","getAlbumsAsync","includeSmartAlbums","title","id","error","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","OS","showWarningPopup","state","loadLocalAlbums","multiple","allowVideo","allowsEditing","askPermissionsAsync","editingAllowed","isEditingEnabled","allowsEditingIOSCamera","result","launchCameraAsync","aspect","exif","canceled","isEmpty","assets","handleImagePicked","mediaTypes","MediaTypeOptions","Videos","showUploadMenu","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 { status: existingStatus } = await MediaLibrary.getPermissionsAsync();\n let status = existingStatus;\n if (status !== 'granted') {\n const { status: newStatus } = await MediaLibrary.requestPermissionsAsync();\n status = newStatus;\n }\n if (status !== 'granted') {\n console.warn('MediaLibrary permission not granted');\n return;\n }\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 showUploadMenu: false,\n showPhotos: true,\n selected: [],\n showRemote: true,\n selectedAlbumId: '',\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 showUploadMenu: false,\n showPhotos: true,\n selected: [],\n showRemote: false,\n selectedAlbumId: '',\n });\n };\n\n hidePhotos = () => {\n this.setState({ showPhotos: false });\n };\n\n openCropper = () => {\n this.setState({ showPhotos: false, showCropper: true });\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":[]}
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 this.setState({ showPhotos: false, showCropper: true });\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":";;;AAAA,OAAOA,KAAK,IAAIC,SAAS,QAAQ,OAAO;AACxC,SAASC,IAAI,EAAEC,UAAU,EAAEC,gBAAgB,EAAEC,IAAI,EAAEC,QAAQ,EAAEC,OAAO,EAAEC,KAAK,EAAEC,UAAU,EAAEC,UAAU,EAAEC,eAAe,QAAQ,cAAc;AAC1I,SAASC,OAAO,QAAQ,aAAa;AACrC,SAASC,IAAI,QAAQ,eAAe;AACpC,OAAOC,CAAC,MAAM,QAAQ;AACtB,SAASC,MAAM,QAAQ,aAAa;AACpC,OAAO,KAAKC,YAAY,MAAM,oBAAoB;AAClD,OAAO,KAAKC,gBAAgB,MAAM,wBAAwB;AAC1D,OAAO,KAAKC,WAAW,MAAM,mBAAmB;AAChD,OAAOC,YAAY,MAAM,2CAA2C;AACpE,OAAOC,oBAAoB,MAAM,wDAAwD;AACzF,OAAOC,MAAM,MAAM,UAAU;AAC7B,SAASC,KAAK,QAAQ,SAAS;AAC/B,SAASC,SAAS,QAAQ,aAAa;AACvC,SAASC,YAAY,QAAQ,gBAAgB;AAC7C,SAASC,iBAAiB,EAAEC,WAAW,EAAEC,OAAO,QAAQ,WAAW;AACnE,SAASC,8BAA8B,EAAEC,OAAO,EAAEC,eAAe,EAAEC,aAAa,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,YAAY;AACzH,OAAOC,MAAM,MAAM,WAAW;AAC9B,SAASC,WAAW,QAAQ,SAAS;AACrC,SAASC,iBAAiB,EAAEC,kBAAkB,QAAQ,YAAY;AAElE,MAAMC,YAAY,GAAG7B,UAAU,CAAC8B,GAAG,CAAC,QAAQ,CAAC,CAACC,KAAK;AACnD,MAAMC,aAAa,GAAGhC,UAAU,CAAC8B,GAAG,CAAC,QAAQ,CAAC,CAACG,MAAM;AACrD,MAAMC,cAAc,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;AAC7B,MAAMC,sBAAsB,GAAG,IAAI;AACnC,MAAMC,iCAAiC,GAAG,KAAK;AAC/C,MAAMC,YAAY,GAAG,IAAI;AACzB,MAAMC,kBAAkB,GAAG,MAAM;AACjC,MAAMC,kBAAkB,GAAG,OAAO;AAClC,MAAMC,kBAAkB,GAAG,OAAO;AAClC,MAAMC,YAAY,GAAG;EACnBV,KAAK,EAAE;AACT,CAAC;AACD,MAAMW,mBAAmB,GAAG,GAAG;AAE/B,MAAMC,aAAa,SAASnD,SAAS,CAAC;EACpCoD,WAAWA,CAACC,KAAK,EAAE;IACjB,KAAK,CAACA,KAAK,CAAC;IAACC,eAAA,0BAwBG,YAAY;MAC5B,MAAMC,aAAa,GAAG,MAAMxC,YAAY,CAACyC,mBAAmB,CAAC,CAAC;MAC9D,IAAI,CAACD,aAAa,CAACE,OAAO,EAAE;MAE5B,IAAI,CAACC,QAAQ,CAAC;QAAEC,mBAAmB,EAAE;MAAK,CAAC,EAAE,YAAY;QACvD,IAAI;UACF,MAAMC,WAAW,GAAG,MAAM7C,YAAY,CAAC8C,cAAc,CAAC;YAAEC,kBAAkB,EAAE;UAAK,CAAC,CAAC;UACnF,IAAI,CAACJ,QAAQ,CAAC;YACZC,mBAAmB,EAAE,KAAK;YAC1BC,WAAW,EAAE,CACX;cACEG,KAAK,EAAE,YAAY;cACnBC,EAAE,EAAE;YACN,CAAC,EACD,GAAGJ,WAAW;UAElB,CAAC,CAAC;QACJ,CAAC,CAAC,OAAOK,KAAK,EAAE;UACdC,OAAO,CAACC,GAAG,CAAC,yBAAyB,EAAEF,KAAK,CAAC;UAC7C,IAAI,CAACP,QAAQ,CAAC;YAAEC,mBAAmB,EAAE;UAAM,CAAC,CAAC;QAC/C;MACF,CAAC,CAAC;IACJ,CAAC;IAAAL,eAAA,2BAEkB,MAAM;MACvB,IAAI,CAACI,QAAQ,CAAC;QAAEU,oBAAoB,EAAE;MAAK,CAAC,EAAE,YAAY;QACxD,IAAI;UACF,MAAMC,WAAW,GAAG,MAAMnC,WAAW,CAACoC,cAAc,CAAC,CAAC;UACtD,IAAI,CAACjB,KAAK,CAAClB,iBAAiB,CAACkC,WAAW,CAAC;UACzC,MAAME,UAAU,GAAG,MAAMrC,WAAW,CAACsC,eAAe,CAAC,IAAI,CAACnB,KAAK,CAACoB,IAAI,CAACC,IAAI,CAAC;UAC1E,IAAI,CAACrB,KAAK,CAACjB,kBAAkB,CAACmC,UAAU,CAACI,IAAI,CAAC;QAChD,CAAC,CAAC,OAAOV,KAAK,EAAE;UACdC,OAAO,CAACC,GAAG,CAAC,0BAA0B,EAAEF,KAAK,CAAC;QAChD,CAAC,SAAS;UACR,IAAI,CAACP,QAAQ,CAAC;YAAEU,oBAAoB,EAAE;UAAM,CAAC,CAAC;QAChD;MACF,CAAC,CAAC;IACJ,CAAC;IAAAd,eAAA,sBAca,OAAOsB,QAAQ,EAAEC,SAAS,KAAK;MAC3C,IAAI;QACF,MAAMC,GAAG,GAAGpD,OAAO,CAACmD,SAAS,CAAC,GAAGD,QAAQ,GAAG,CAAC,MAAM,IAAI,CAACG,gBAAgB,CAACH,QAAQ,CAAC,EAAEE,GAAG;QACvF,MAAME,GAAG,GAAG,MAAM9C,WAAW,CAAC+C,2BAA2B,CAACH,GAAG,EAAED,SAAS,EAAEK,QAAQ,IAAI;UACpF,IAAI,IAAI,CAAC7B,KAAK,CAAC8B,gBAAgB,EAAE,IAAI,CAAC9B,KAAK,CAAC8B,gBAAgB,CAACD,QAAQ,CAAC;QACxE,CAAC,CAAC;QACF,IAAI,CAAC7B,KAAK,CAAC+B,eAAe,CAACnD,MAAM,CAACoD,GAAG,CAACC,cAAc,GAAGN,GAAG,CAACO,GAAG,EAAEV,SAAS,CAAC;QAC1EX,OAAO,CAACC,GAAG,CAAC,uBAAuB,EAAElC,MAAM,CAACoD,GAAG,CAACC,cAAc,GAAGN,GAAG,CAACO,GAAG,CAAC;MAC3E,CAAC,CAAC,OAAOC,CAAC,EAAE;QACVtB,OAAO,CAACC,GAAG,CAAC,mBAAmB,EAAEqB,CAAC,CAAC;QACnC,IAAI,CAACnC,KAAK,CAACoC,cAAc,CAACZ,SAAS,CAAC;MACtC;IACF,CAAC;IAAAvB,eAAA,2BAEkB,MAAMwB,GAAG,IAAI;MAC9B,MAAMY,OAAO,GAAG,CACd;QACEC,MAAM,EAAEnE,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAACuC,IAAI,EAAE3C,YAAY;MACzD,CAAC,CACF;MACD,MAAM4C,WAAW,GAAG;QAClBC,MAAM,EAAEhD,kBAAkB;QAC1BiD,QAAQ,EAAEvE,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAAC2C,OAAO,EAAE9C,mBAAmB,CAAC;QACpE+C,MAAM,EAAE;MACV,CAAC;MACD,OAAO,MAAMjF,gBAAgB,CAACkF,eAAe,CAACpB,GAAG,EAAEY,OAAO,EAAEG,WAAW,CAAC;IAC1E,CAAC;IAAAvC,eAAA,4BAEmB,MAAM6C,QAAQ,IAAI;MACpC,IAAItB,SAAS;MACb,IAAI;QACF,MAAMuB,QAAQ,GAAG,GAAG5E,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAAC+C,QAAQ,EAAErD,kBAAkB,CAAC,IAAID,kBAAkB,EAAE;QAEtG,IAAI,CAACuD,cAAc,CAAC,CAAC;QAErB,MAAMC,OAAO,GAAG,MAAM,IAAI,CAACvB,gBAAgB,CAACoB,QAAQ,CAAC;QACrD,MAAMI,IAAI,GAAG,MAAMrE,WAAW,CAACsE,WAAW,CAACF,OAAO,CAACxB,GAAG,CAAC;QACvD,MAAM2B,eAAe,GAAG,MAAMvE,WAAW,CAACwE,eAAe,CAAC7F,CAAC,CAAC8F,IAAI,CAACL,OAAO,CAACxB,GAAG,CAAC8B,KAAK,CAAC,GAAG,CAAC,CAAC,EAAEL,IAAI,CAACM,IAAI,CAAC;QACpGhC,SAAS,GAAG4B,eAAe,CAAClB,GAAG;QAC/B,IAAI,CAAClC,KAAK,CAACyD,eAAe,CAACjC,SAAS,EAAEsB,QAAQ,CAAC;QAC/C,IAAI,IAAI,CAAC9C,KAAK,CAAC0D,eAAe,EAAE;UAC9B,IAAI,CAAC1D,KAAK,CAAC2D,eAAe,CAACV,OAAO,EAAEF,QAAQ,CAAC;UAC7C;QACF;QAEA,MAAMa,YAAY,GAAG,MAAM/E,WAAW,CAAC+C,2BAA2B,CAACsB,IAAI,EAAEE,eAAe,CAACS,GAAG,EAAEhC,QAAQ,IAAI;UACxG,IAAI,IAAI,CAAC7B,KAAK,CAAC8B,gBAAgB,EAAE,IAAI,CAAC9B,KAAK,CAAC8B,gBAAgB,CAACD,QAAQ,CAAC;QACxE,CAAC,CAAC;QAEF,IAAI,CAAC7B,KAAK,CAAC+B,eAAe,CAACnD,MAAM,CAACoD,GAAG,CAACC,cAAc,GAAGT,SAAS,EAAEA,SAAS,CAAC;QAC5EX,OAAO,CAACC,GAAG,CAAC,gBAAgB,EAAElC,MAAM,CAACoD,GAAG,CAACC,cAAc,GAAGT,SAAS,CAAC;MACtE,CAAC,CAAC,OAAOW,CAAC,EAAE;QACVtB,OAAO,CAACC,GAAG,CAAC,yBAAyB,EAAEqB,CAAC,CAAC;QACzC,IAAI,CAACnC,KAAK,CAACoC,cAAc,CAACZ,SAAS,CAAC;MACtC;IACF,CAAC;IAAAvB,eAAA,iCAEwB,MAAM6D,cAAc,IAAI;MAC/C;MACA,MAAMC,cAAc,GAAGD,cAAc,CAACE,GAAG,CAACC,KAAK,IAAI;QACjD,MAAMlB,QAAQ,GAAG,GAAG5E,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAAC+C,QAAQ,EAAErD,kBAAkB,CAAC,IAAID,kBAAkB,EAAE;QACtG,MAAM+B,SAAS,GAAG3C,WAAW,CAACqF,YAAY,CAAC,IAAI,CAAClE,KAAK,CAACmE,MAAM,EAAEpB,QAAQ,CAAC;QACvE,OAAO;UAAED,QAAQ,EAAEmB,KAAK,CAACxC,GAAG;UAAED,SAAS;UAAEuB;QAAS,CAAC;MACrD,CAAC,CAAC;MACF,IAAI,CAACC,cAAc,CAAC,CAAC;;MAErB;MACA,KAAK,IAAIoB,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGL,cAAc,CAACM,MAAM,EAAED,CAAC,EAAE,EAAE;QAC9C,MAAMH,KAAK,GAAGF,cAAc,CAACK,CAAC,CAAC;QAC/B,MAAM;UAAEtB,QAAQ;UAAEtB,SAAS;UAAEuB;QAAS,CAAC,GAAGkB,KAAK;QAC/C,IAAI;UACF,MAAMhB,OAAO,GAAG,MAAM,IAAI,CAACvB,gBAAgB,CAACoB,QAAQ,CAAC;UACrD,MAAMI,IAAI,GAAG,MAAMrE,WAAW,CAACsE,WAAW,CAACF,OAAO,CAACxB,GAAG,CAAC;UACvD,IAAI,IAAI,CAACzB,KAAK,CAAC0D,eAAe,EAAE;YAC9B,IAAI,CAAC1D,KAAK,CAAC2D,eAAe,CAACV,OAAO,EAAEF,QAAQ,CAAC;YAC7C;UACF;UACA,MAAMK,eAAe,GAAG,MAAMvE,WAAW,CAACwE,eAAe,CAAC7F,CAAC,CAAC8F,IAAI,CAACL,OAAO,CAACxB,GAAG,CAAC8B,KAAK,CAAC,GAAG,CAAC,CAAC,EAAEL,IAAI,CAACM,IAAI,CAAC;UACpG,MAAMhC,SAAS,GAAG4B,eAAe,CAAClB,GAAG;UACrC,IAAI,CAAC,IAAI,CAAClC,KAAK,CAAC0D,eAAe,EAAE,IAAI,CAAC1D,KAAK,CAACyD,eAAe,CAACjC,SAAS,EAAEsB,QAAQ,CAAC;UAEhF,MAAMc,YAAY,GAAG,MAAM/E,WAAW,CAAC+C,2BAA2B,CAACsB,IAAI,EAAEE,eAAe,CAACS,GAAG,EAAEhC,QAAQ,IAAI;YACxG,IAAI,IAAI,CAAC7B,KAAK,CAAC8B,gBAAgB,EAAE,IAAI,CAAC9B,KAAK,CAAC8B,gBAAgB,CAACD,QAAQ,CAAC;UACxE,CAAC,CAAC;UAEF,IAAI,CAAC7B,KAAK,CAAC+B,eAAe,CAACnD,MAAM,CAACoD,GAAG,CAACC,cAAc,GAAGT,SAAS,EAAEA,SAAS,CAAC;UAC5EX,OAAO,CAACC,GAAG,CAAC,gBAAgB,EAAElC,MAAM,CAACoD,GAAG,CAACC,cAAc,GAAGT,SAAS,CAAC;QACtE,CAAC,CAAC,OAAOW,CAAC,EAAE;UACVtB,OAAO,CAACC,GAAG,CAAC,8BAA8B,EAAEqB,CAAC,CAAC;UAC9C,IAAI,CAACnC,KAAK,CAACoC,cAAc,CAACZ,SAAS,CAAC;QACtC;MACF;IACF,CAAC;IAAAvB,eAAA,4BAEmB,MAAMwB,GAAG,IAAI;MAC/B,IAAID,SAAS;MACb,IAAI;QACF,MAAM8C,QAAQ,GAAG7C,GAAG,CAAC8C,SAAS,CAAC9C,GAAG,CAAC+C,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACxD,MAAMzB,QAAQ,GAAG,GAAG5E,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAAC+C,QAAQ,EAAEpD,kBAAkB,CAAC,IAAI2E,QAAQ,EAAE;QAC5F,MAAMpB,IAAI,GAAG,MAAMrE,WAAW,CAACsE,WAAW,CAAC1B,GAAG,CAAC;QAC/C,MAAM2B,eAAe,GAAG,MAAMvE,WAAW,CAACwE,eAAe,CAACN,QAAQ,EAAEG,IAAI,CAACM,IAAI,CAAC;QAC9EhC,SAAS,GAAG4B,eAAe,CAAClB,GAAG;QAE/B,IAAI,CAAClC,KAAK,CAACyD,eAAe,CAACjC,SAAS,EAAEC,GAAG,CAAC;QAC1C,IAAI,CAACuB,cAAc,CAAC,CAAC;QAErB,MAAMY,YAAY,GAAG,MAAM/E,WAAW,CAAC+C,2BAA2B,CAACsB,IAAI,EAAEE,eAAe,CAACS,GAAG,EAAEhC,QAAQ,IAAI;UACxG,IAAI,IAAI,CAAC7B,KAAK,CAAC8B,gBAAgB,EAAE,IAAI,CAAC9B,KAAK,CAAC8B,gBAAgB,CAACD,QAAQ,CAAC;QACxE,CAAC,CAAC;QAEF,IAAI,CAAC7B,KAAK,CAAC+B,eAAe,CAACnD,MAAM,CAACoD,GAAG,CAACC,cAAc,GAAGT,SAAS,EAAEA,SAAS,CAAC;QAC5EX,OAAO,CAACC,GAAG,CAAC,gBAAgB,EAAElC,MAAM,CAACoD,GAAG,CAACC,cAAc,GAAGT,SAAS,CAAC;MACtE,CAAC,CAAC,OAAOW,CAAC,EAAE;QACVtB,OAAO,CAACC,GAAG,CAAC,yBAAyB,EAAEqB,CAAC,CAAC;QACzC,IAAI,CAACnC,KAAK,CAACoC,cAAc,CAACZ,SAAS,CAAC;MACtC;IACF,CAAC;IAAAvB,eAAA,8BAmCqB,YAAY;MAAA,IAAAwE,qBAAA;MAChC,MAAMC,gBAAgB,GAAG,MAAMjH,MAAM,CAACkH,6BAA6B,CAAC,CAAC;MACrE,MAAMC,cAAc,GAAG,MAAMlH,YAAY,CAACmH,uBAAuB,CAAC,CAAC;MACnE,IAAIH,gBAAgB,CAACI,MAAM,KAAK,SAAS,IAAK9H,QAAQ,CAAC+H,EAAE,KAAK,KAAK,IAAIH,cAAc,CAACE,MAAM,KAAK,SAAU,EAAE;QAC3G,IAAI,CAACE,gBAAgB,CAACN,gBAAgB,CAACI,MAAM,KAAK,SAAS,EAAEF,cAAc,CAACE,MAAM,KAAK,SAAS,CAAC;QACjG,OAAO,KAAK;MACd;MACA,IAAI,EAAAL,qBAAA,OAAI,CAACQ,KAAK,CAAC1E,WAAW,cAAAkE,qBAAA,uBAAtBA,qBAAA,CAAwBJ,MAAM,KAAI,CAAC,EAAE,IAAI,CAACa,eAAe,CAAC,CAAC;MAE/D,OAAO,IAAI;IACb,CAAC;IAAAjF,eAAA,2BAEkB,MAAM;MACvB,OAAO,KAAK;MACZ,OAAO,CAAC,IAAI,CAACD,KAAK,CAACmF,QAAQ,IAAI,CAAC,IAAI,CAACnF,KAAK,CAACoF,UAAU,IAAIjH,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAACqF,aAAa,EAAE/F,sBAAsB,CAAC;IAC9H,CAAC;IAAAW,eAAA,qBAEY,YAAY;MACvB,IAAI,EAAE,MAAM,IAAI,CAACqF,mBAAmB,CAAC,CAAC,CAAC,EAAE;MAEzC,IAAIC,cAAc,GAAG,IAAI,CAACC,gBAAgB,CAAC,CAAC;MAC5C,IAAIxI,QAAQ,CAAC+H,EAAE,KAAK,KAAK,EAAE;QACzBQ,cAAc,GAAGpH,iBAAiB,CAChC,IAAI,CAAC6B,KAAK,CAACyF,sBAAsB,EACjCtH,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAACqF,aAAa,EAAE9F,iCAAiC,CAC/E,CAAC;MACH;MACA,MAAMmG,MAAM,GAAG,MAAM9H,WAAW,CAAC+H,iBAAiB,CAAC;QACjDN,aAAa,EAAEE,cAAc;QAC7BK,MAAM,EAAEzH,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAAC4F,MAAM,EAAEvG,cAAc,CAAC;QAC5DwG,IAAI,EAAE1H,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAAC6F,IAAI,EAAErG,YAAY;MACvD,CAAC,CAAC;MAEF,IAAI,CAACkG,MAAM,CAACI,QAAQ,IAAI,CAACtI,CAAC,CAACuI,OAAO,CAACL,MAAM,CAACM,MAAM,CAAC,EAAE;QACjD,IAAI,CAACC,iBAAiB,CAACP,MAAM,CAACM,MAAM,CAAC,CAAC,CAAC,CAACvE,GAAG,CAAC;MAC9C;IACF,CAAC;IAAAxB,eAAA,0BAEiB,YAAY;MAC5B,IAAI,EAAE,MAAM,IAAI,CAACqF,mBAAmB,CAAC,CAAC,CAAC,EAAE;MAEzC,MAAMI,MAAM,GAAG,MAAM9H,WAAW,CAAC+H,iBAAiB,CAAC;QACjDN,aAAa,EAAE,IAAI,CAACG,gBAAgB,CAAC,CAAC;QACtCU,UAAU,EAAEtI,WAAW,CAACuI,gBAAgB,CAACC;MAC3C,CAAC,CAAC;MAEF,IAAI,CAACV,MAAM,CAACI,QAAQ,IAAI,CAACtI,CAAC,CAACuI,OAAO,CAACL,MAAM,CAACM,MAAM,CAAC,EAAE;QACjD,IAAI,CAACC,iBAAiB,CAACP,MAAM,CAACM,MAAM,CAAC,CAAC,CAAC,CAACvE,GAAG,CAAC;MAC9C;IACF,CAAC;IAAAxB,eAAA,sBAEa,YAAY;MACxB,IAAI,CAACI,QAAQ,CACX;QACEgG,cAAc,EAAE;MAClB,CAAC,EACD,MAAM;QACJC,UAAU,CAAC,MAAM;UACf,IAAI,CAACjG,QAAQ,CAAC;YACZkG,UAAU,EAAE,IAAI;YAChBC,QAAQ,EAAE,EAAE;YACZC,UAAU,EAAE,IAAI;YAChBC,eAAe,EAAE;UACnB,CAAC,CAAC;QACJ,CAAC,EAAE,IAAI,CAAC;MACV,CACF,CAAC;IACH,CAAC;IAAAzG,eAAA,qBAEY,YAAY;MACvB,IAAIjD,QAAQ,CAAC+H,EAAE,KAAK,SAAS,EAAE;QAC7B,MAAMW,MAAM,GAAG,MAAM9H,WAAW,CAAC+I,uBAAuB,CAAC;UACvDtB,aAAa,EAAE,IAAI,CAACG,gBAAgB,CAAC,CAAC;UACtCI,MAAM,EAAEzH,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAAC4F,MAAM,EAAEvG,cAAc,CAAC;UAC5DwG,IAAI,EAAE1H,iBAAiB,CAAC,IAAI,CAAC6B,KAAK,CAAC6F,IAAI,EAAErG,YAAY,CAAC;UACtD0G,UAAU,EAAE,IAAI,CAAClG,KAAK,CAACoF,UAAU,GAAGxH,WAAW,CAACuI,gBAAgB,CAACS,GAAG,GAAGhJ,WAAW,CAACuI,gBAAgB,CAACU;QACtG,CAAC,CAAC;QACF,IAAI,CAACnB,MAAM,CAACoB,SAAS,EAAE;UACrB,IAAIpB,MAAM,CAACM,MAAM,CAAC3B,MAAM,KAAK,CAAC,IAAIqB,MAAM,CAACM,MAAM,CAAC,CAAC,CAAC,CAACxC,IAAI,KAAK,OAAO,EAAE;YACnE,IAAI,CAACuD,iBAAiB,CAACrB,MAAM,CAACM,MAAM,CAAC,CAAC,CAAC,CAACvE,GAAG,CAAC;UAC9C,CAAC,MAAM;YACL,IAAI,CAACuF,sBAAsB,CAACtB,MAAM,CAACM,MAAM,CAAC;UAC5C;QACF;QACA;MACF;;MAEA;MACA,IAAI,EAAE,MAAM,IAAI,CAACV,mBAAmB,CAAC,CAAC,CAAC,EAAE;MAEzC,IAAI,CAACjF,QAAQ,CACX;QACEgG,cAAc,EAAE;MAClB,CAAC,EACD,MAAM;QACJC,UAAU,CAAC,MAAM;UACf,IAAI,CAACjG,QAAQ,CAAC;YACZkG,UAAU,EAAE,IAAI;YAChBC,QAAQ,EAAE,EAAE;YACZC,UAAU,EAAE,KAAK;YACjBC,eAAe,EAAE;UACnB,CAAC,CAAC;QACJ,CAAC,EAAE,IAAI,CAAC;MACV,CACF,CAAC;IACH,CAAC;IAAAzG,eAAA,qBAEY,MAAM;MACjB,IAAI,CAACI,QAAQ,CAAC;QAAEkG,UAAU,EAAE;MAAM,CAAC,CAAC;IACtC,CAAC;IAAAtG,eAAA,sBAEa,MAAM;MAClB,IAAI,CAACI,QAAQ,CAAC;QAAEkG,UAAU,EAAE,KAAK;QAAEU,WAAW,EAAE;MAAK,CAAC,CAAC;IACzD,CAAC;IAAAhH,eAAA,wBAEe,MAAM;MACpB,IAAI,CAACI,QAAQ,CAAC;QAAE4G,WAAW,EAAE,CAAC,IAAI,CAAChC,KAAK,CAACgC;MAAY,CAAC,CAAC;IACzD,CAAC;IAAAhH,eAAA,wBAEe,MAAM;MACpB,IAAI,CAACI,QAAQ,CAAC;QAAE6G,eAAe,EAAE;MAAK,CAAC,CAAC;IAC1C,CAAC;IAAAjH,eAAA,8BAEqB,MAAM;MAC1B,IAAI,CAACI,QAAQ,CAAC;QAAE6G,eAAe,EAAE;MAAM,CAAC,CAAC;IAC3C,CAAC;IAAAjH,eAAA,0BAEiByG,eAAe,IAAI;MACnC,IAAI,CAACrG,QAAQ,CAAC;QAAE6G,eAAe,EAAE,KAAK;QAAER;MAAgB,CAAC,CAAC;IAC5D,CAAC;IAAAzG,eAAA,4BAEmB,CAACuG,QAAQ,EAAEW,aAAa,EAAEC,QAAQ,KAAK;MACzD,IAAI,CAAC/G,QAAQ,CAAC;QACZmG,QAAQ;QACRa,YAAY,EAAEF,aAAa,GAAG,OAAO,GAAG,OAAO;QAC/CC;MACF,CAAC,CAAC;IACJ,CAAC;IAAAnH,eAAA,qBAEY,MAAMqH,QAAQ,IAAI;MAC7B,IAAI,IAAI,CAAC9B,gBAAgB,CAAC,CAAC,EAAE;QAC3B,IAAI,CAAC+B,WAAW,CAAC,CAAC;MACpB,CAAC,MAAM;QACL,MAAMC,aAAa,GAAG,MAAMF,QAAQ;QACpC;QACA,IAAI,IAAI,CAACrC,KAAK,CAACwB,UAAU,EAAE;UACzB,IAAI,IAAI,CAACzG,KAAK,CAACyH,iBAAiB,EAAE;YAChCD,aAAa,CAACxD,GAAG,CAAC0D,KAAK,IAAI;cACzB,IAAI,CAAC1H,KAAK,CAACyH,iBAAiB,CAACC,KAAK,CAACjG,GAAG,CAAC;YACzC,CAAC,CAAC;UACJ;QACF,CAAC,MAAM;UACL,IAAI+F,aAAa,CAAC,CAAC,CAAC,CAACG,SAAS,KAAKjK,YAAY,CAACkK,SAAS,CAACC,KAAK,EAAE;YAC/D,MAAMpG,GAAG,GAAG+F,aAAa,CAAC,CAAC,CAAC,CAACM,QAAQ,IAAIN,aAAa,CAAC,CAAC,CAAC,CAAC/F,GAAG;YAC7DZ,OAAO,CAACC,GAAG,CAAC,gBAAgB,CAAC;YAC7B,IAAI,CAACiG,iBAAiB,CAACtF,GAAG,CAAC;UAC7B,CAAC,MAAM;YACL,IAAI,CAACuF,sBAAsB,CAACQ,aAAa,CAAC;UAC5C;QACF;QAEA,IAAI,CAACO,UAAU,CAAC,CAAC;MACnB;IACF,CAAC;IAAA9H,eAAA,wBAEewB,GAAG,IAAI;MACrB,MAAM+E,QAAQ,GAAG,CAAC,GAAG,IAAI,CAACvB,KAAK,CAACuB,QAAQ,CAAC;MACzC,MAAMwB,WAAW,GAAGxB,QAAQ,CAACyB,OAAO,CAACxG,GAAG,CAAC;MACzC+E,QAAQ,CAAC0B,MAAM,CAACF,WAAW,EAAE,CAAC,CAAC;MAC/B,IAAI,CAAC3H,QAAQ,CAAC;QAAEmG;MAAS,CAAC,CAAC;IAC7B,CAAC;IAAAvG,eAAA,uBAEc,MAAM;MACnB,MAAMkI,OAAO,GAAG,CACd;QACEC,IAAI,EAAE,YAAY;QAClBC,OAAO,EAAE,IAAI,CAACC;MAChB,CAAC,CACF;MACD,IAAI,IAAI,CAACtI,KAAK,CAACoF,UAAU,EACvB+C,OAAO,CAACI,IAAI,CAAC;QACXH,IAAI,EAAE,cAAc;QACpBC,OAAO,EAAE,IAAI,CAACG;MAChB,CAAC,CAAC;MACJL,OAAO,CAACI,IAAI,CAAC;QACXH,IAAI,EAAE,aAAa;QACnBC,OAAO,EAAE,IAAI,CAACI;MAChB,CAAC,CAAC;MACF,IAAI,CAAC,IAAI,CAACzI,KAAK,CAAC0I,WAAW,EACzBP,OAAO,CAACI,IAAI,CAAC;QACXH,IAAI,EAAE,eAAe;QACrBC,OAAO,EAAE,IAAI,CAACM;MAChB,CAAC,CAAC;MAEJ,OAAOR,OAAO;IAChB,CAAC;IAAAlI,eAAA,kCA0CyB2I,kBAAkB,IAAI;MAC9C,oBACElM,KAAA,CAAAmM,aAAA,CAACjM,IAAI;QAACkM,KAAK,EAAEC,MAAM,CAACC;MAAsB,gBACxCtM,KAAA,CAAAmM,aAAA,CAACjM,IAAI;QAACkM,KAAK,EAAE,CAACC,MAAM,CAACE,uBAAuB,EAAE;UAAEC,eAAe,EAAE,IAAI,CAAClJ,KAAK,CAACmJ;QAAmB,CAAC;MAAE,GAC/F,IAAI,CAACnJ,KAAK,CAACmF,QAAQ,gBAClBzI,KAAA,CAAAmM,aAAA,CAAC9L,IAAI;QAAC+L,KAAK,EAAEC,MAAM,CAACK;MAAiB,GAAER,kBAAyB,CAAC,gBAEjElM,KAAA,CAAAmM,aAAA,CAACtL,IAAI;QAAC8L,IAAI,EAAC,OAAO;QAAC7F,IAAI,EAAC,cAAc;QAAC8F,SAAS,EAAEP,MAAM,CAACQ;MAAiB,CAAE,CAE1E,CACF,CAAC;IAEX,CAAC;IAzdC,IAAI,CAACtE,KAAK,GAAG;MACXoB,cAAc,EAAE,KAAK;MACrBmD,OAAO,EAAE,IAAI;MACbjD,UAAU,EAAE,KAAK;MACjBE,UAAU,EAAE,KAAK;MACjBD,QAAQ,EAAE,EAAE;MACZa,YAAY,EAAE,EAAE;MAChBD,QAAQ,EAAE,IAAI;MACdV,eAAe,EAAE,EAAE;MACnBQ,eAAe,EAAE,KAAK;MACtBD,WAAW,EAAE,KAAK;MAClB1G,WAAW,EAAE,EAAE;MACfD,mBAAmB,EAAE,KAAK;MAC1BS,oBAAoB,EAAE;IACxB,CAAC;EACH;EAEA0I,iBAAiBA,CAAA,EAAG;IAClB,IAAI,CAACvE,eAAe,CAAC,CAAC;IACtB,IAAI,CAACwE,gBAAgB,CAAC,CAAC;EACzB;EAyCArD,cAAcA,CAAA,EAAG;IACf,IAAI,CAAChG,QAAQ,CAAC;MACZgG,cAAc,EAAE;IAClB,CAAC,CAAC;EACJ;EAEArD,cAAcA,CAAA,EAAG;IACf,IAAI,CAAC3C,QAAQ,CAAC;MACZgG,cAAc,EAAE;IAClB,CAAC,CAAC;EACJ;EAwHArB,gBAAgBA,CAAC2E,MAAM,EAAEC,IAAI,EAAE;IAC7B,IAAI5M,QAAQ,CAAC+H,EAAE,KAAK,KAAK,EAAE;MACzB;IACF;IACA,IAAI8E,YAAY,GAAG,EAAE;IACrB,IAAIF,MAAM,IAAIC,IAAI,EAAE;MAClBC,YAAY,GAAG,oCAAoC;IACrD,CAAC,MAAM,IAAIF,MAAM,EAAE;MACjBE,YAAY,GAAG,aAAa;IAC9B,CAAC,MAAM,IAAID,IAAI,EAAE;MACfC,YAAY,GAAG,oBAAoB;IACrC,CAAC,MAAM;MACL;MACA;IACF;IACA,IAAI,CAACxJ,QAAQ,CAAC;MACZmJ,OAAO,EAAE,4BAA4BK,YAAY;IACnD,CAAC,CAAC;EACJ;EAEAC,iBAAiBA,CAAA,EAAG;IAClB,IAAI,CAACzJ,QAAQ,CAAC;MACZmJ,OAAO,EAAE;IACX,CAAC,CAAC;EACJ;EAEAO,sBAAsBA,CAAA,EAAG;IACvB9M,OAAO,CAAC+M,OAAO,CAAC,eAAe,CAAC;IAChC,IAAI,CAAC3J,QAAQ,CAAC;MACZmJ,OAAO,EAAE;IACX,CAAC,CAAC;EACJ;EAuMAS,sBAAsBA,CAAA,EAAG;IACvB,MAAM;MAAEzD,QAAQ;MAAEC;IAAW,CAAC,GAAG,IAAI,CAACxB,KAAK;IAE3C,oBACEvI,KAAA,CAAAmM,aAAA,CAACjM,IAAI,qBACHF,KAAA,CAAAmM,aAAA,CAAChM,UAAU;MAACqN,UAAU;MAACC,8BAA8B,EAAE,KAAM;MAACC,qBAAqB,EAAErB,MAAM,CAACsB;IAA0B,GACnH7D,QAAQ,IACPA,QAAQ,CAACxC,GAAG,CAACvC,GAAG,IAAI;MAClB,MAAMqB,QAAQ,GAAG2D,UAAU,GAAGrI,WAAW,CAACqD,GAAG,CAAC,GAAGA,GAAG;MACpD,oBACE/E,KAAA,CAAAmM,aAAA,CAACjM,IAAI;QAACsF,GAAG,EAAET,GAAI;QAACqH,KAAK,EAAEC,MAAM,CAACuB;MAAqB,gBACjD5N,KAAA,CAAAmM,aAAA,CAACxL,eAAe;QAACyL,KAAK,EAAEC,MAAM,CAACwB,gBAAiB;QAACC,MAAM,EAAE;UAAE/I,GAAG,EAAEqB;QAAS;MAAE,CAAE,CAAC,eAC9EpG,KAAA,CAAAmM,aAAA,CAAC/L,gBAAgB;QAACgM,KAAK,EAAEC,MAAM,CAAC0B,uBAAwB;QAACpC,OAAO,EAAEA,CAAA,KAAM,IAAI,CAACqC,aAAa,CAACjJ,GAAG;MAAE,gBAC9F/E,KAAA,CAAAmM,aAAA,CAACjM,IAAI;QAACkM,KAAK,EAAE,CAACC,MAAM,CAAC4B,0BAA0B,EAAE;UAAEzB,eAAe,EAAE,IAAI,CAAClJ,KAAK,CAACmJ;QAAmB,CAAC;MAAE,gBACnGzM,KAAA,CAAAmM,aAAA,CAACtL,IAAI;QAAC8L,IAAI,EAAC,OAAO;QAAC7F,IAAI,EAAC,cAAc;QAAC8F,SAAS,EAAEP,MAAM,CAAC6B;MAAsB,CAAE,CAC7E,CACU,CACd,CAAC;IAEX,CAAC,CACO,CACR,CAAC;EAEX;EAEAC,mBAAmBA,CAAA,EAAG;IACpB,MAAM;MAAEtK,WAAW;MAAEmG,eAAe;MAAED;IAAW,CAAC,GAAG,IAAI,CAACxB,KAAK;IAC/D,MAAM6F,aAAa,GAAG,CAACrE,UAAU,GAAG,IAAI,CAACzG,KAAK,CAAC+K,YAAY,GAAGxK,WAAW,EAAEyK,IAAI,CAACC,KAAK,IAAIA,KAAK,CAACtK,EAAE,KAAK+F,eAAe,CAAC;IACtH,MAAMwE,iBAAiB,GAAGJ,aAAa,GAAGA,aAAa,CAACpK,KAAK,GAAG,EAAE;IAElE,oBACEhE,KAAA,CAAAmM,aAAA,CAAC/L,gBAAgB;MAACuL,OAAO,EAAE,IAAI,CAAC8C;IAAc,gBAC5CzO,KAAA,CAAAmM,aAAA,CAACjM,IAAI;MAACkM,KAAK,EAAEC,MAAM,CAACqC;IAAkB,gBACpC1O,KAAA,CAAAmM,aAAA,CAAC9L,IAAI;MAAC+L,KAAK,EAAEC,MAAM,CAACsC;IAAsB,GAAEH,iBAAwB,CAAC,eACrExO,KAAA,CAAAmM,aAAA,CAACtL,IAAI;MAAC8L,IAAI,EAAC,YAAY;MAAC7F,IAAI,EAAC,cAAc;MAAC8F,SAAS,EAAEP,MAAM,CAACuC;IAAsB,CAAE,CAClF,CACU,CAAC;EAEvB;EAgBAC,aAAaA,CAAA,EAAG;IACd,MAAM;MAAE/E,QAAQ;MAAEE,eAAe;MAAED;IAAW,CAAC,GAAG,IAAI,CAACxB,KAAK;IAC5D,MAAM;MAAEuG,WAAW;MAAErG,QAAQ;MAAEC,UAAU;MAAE2F;IAAa,CAAC,GAAG,IAAI,CAAC/K,KAAK;IACtE,MAAMd,KAAK,GAAG,CAACF,YAAY,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC;IAEzC,oBACEtC,KAAA,CAAAmM,aAAA,CAAChL,YAAY;MACX4N,GAAG,EAAE,CAACtG,QAAQ,GAAG,CAAC,GAAGqG,WAAY;MACjCE,SAAS,EAAE,EAAG;MACdC,QAAQ,EAAE,IAAI,CAACC,iBAAkB;MACjCC,uBAAuB,EAAE,IAAI,CAACA,uBAAwB;MACtDvE,QAAQ,EAAE,IAAI,CAACwE,UAAW;MAC1BtF,QAAQ,EAAEA,QAAS;MACnBpB,UAAU,EAAEA,UAAW;MACvB0D,KAAK,EAAEC,MAAM,CAACgD,gBAAiB;MAC/BC,SAAS,EAAEjD,MAAM,CAACkD,aAAc;MAChCC,SAAS,EAAEhN,KAAM;MACjBiN,UAAU,EAAEjN,KAAM;MAClB+L,KAAK,EAAEvE,eAAgB;MACvB0F,YAAY,EAAE3F,UAAU,GAAGsE,YAAY,GAAG;IAAK,CAChD,CAAC;EAEN;EAEAsB,kBAAkBA,CAAA,EAAG;IACnB,MAAM;MAAE7F,QAAQ;MAAEa;IAAa,CAAC,GAAG,IAAI,CAACpC,KAAK;IAC7C,MAAMqH,SAAS,GAAG9F,QAAQ,CAACnC,MAAM,GAAG,CAAC,IAAI,CAAC7G,CAAC,CAACuI,OAAO,CAACsB,YAAY,CAAC;IACjE,MAAMkF,UAAU,GAAG,UAAUD,SAAS,GAAG9F,QAAQ,CAACnC,MAAM,GAAG,EAAE,IAAIiI,SAAS,GAAGjF,YAAY,GAAG,EAAE,GAAGb,QAAQ,CAACnC,MAAM,GAAG,CAAC,GAAG,GAAG,GAAG,EAAE,EAAE;IAEjI,oBACE3H,KAAA,CAAAmM,aAAA,CAACjM,IAAI;MAACkM,KAAK,EAAEC,MAAM,CAACyD;IAAgB,gBAClC9P,KAAA,CAAAmM,aAAA,CAAC3K,YAAY;MACXuO,KAAK,EAAEH,SAAS,GAAG,IAAI,CAACtM,KAAK,CAACmJ,kBAAkB,GAAG3K,eAAgB;MACnE6J,OAAO,EAAE,IAAI,CAACpD,KAAK,CAACmC,QAAS;MAC7BsF,aAAa;MACbC,KAAK;MACLC,QAAQ,EAAE,CAACN;IAAU,GAEpBC,UACW,CACV,CAAC;EAEX;EAEAM,sBAAsBA,CAAA,EAAG;IACvB,MAAM;MAAE3F,eAAe;MAAE3G,WAAW;MAAEkG;IAAW,CAAC,GAAG,IAAI,CAACxB,KAAK;IAC/D,IAAI,CAACiC,eAAe,EAAE,OAAO,IAAI;IAEjC,oBACExK,KAAA,CAAAmM,aAAA,CAAC3L,KAAK;MAAC4P,OAAO;MAACC,WAAW;MAACC,aAAa,EAAC,OAAO;MAACC,cAAc,EAAE,IAAI,CAACC;IAAoB,gBACxFxQ,KAAA,CAAAmM,aAAA,CAACjM,IAAI;MAACkM,KAAK,EAAEC,MAAM,CAACoE;IAAiB,gBACnCzQ,KAAA,CAAAmM,aAAA,CAACjM,IAAI;MAACkM,KAAK,EAAEC,MAAM,CAACqE;IAAqB,gBACvC1Q,KAAA,CAAAmM,aAAA,CAACjM,IAAI;MAACkM,KAAK,EAAEC,MAAM,CAACsE;IAA0B,gBAC5C3Q,KAAA,CAAAmM,aAAA,CAAC9L,IAAI;MAAC+L,KAAK,EAAEC,MAAM,CAACuE;IAAiB,GAAC,cAAkB,CACpD,CAAC,eACP5Q,KAAA,CAAAmM,aAAA,CAAChM,UAAU,QACR,CAAC4J,UAAU,GAAG,IAAI,CAACzG,KAAK,CAAC+K,YAAY,GAAGxK,WAAW,EAAEyD,GAAG,CAAC,CAACiH,KAAK,EAAEsC,KAAK,KAAK;MAC1E,oBACE7Q,KAAA,CAAAmM,aAAA,CAAC/L,gBAAgB;QAACoF,GAAG,EAAE+I,KAAK,CAACtK,EAAG;QAAC0H,OAAO,EAAEA,CAAA,KAAM,IAAI,CAACmF,eAAe,CAACvC,KAAK,CAACtK,EAAE;MAAE,gBAC7EjE,KAAA,CAAAmM,aAAA,CAACjM,IAAI;QAACkM,KAAK,EAAE,CAACC,MAAM,CAAC0E,oBAAoB,EAAEF,KAAK,KAAK,CAAC,IAAI;UAAEG,cAAc,EAAE;QAAE,CAAC;MAAE,gBAC/EhR,KAAA,CAAAmM,aAAA,CAAC9L,IAAI;QAAC+L,KAAK,EAAEC,MAAM,CAAC4E;MAAgB,GAAE1C,KAAK,CAACvK,KAAY,CACpD,CACU,CAAC;IAEvB,CAAC,CACS,CAAC,eACbhE,KAAA,CAAAmM,aAAA,CAAC/L,gBAAgB;MAACuL,OAAO,EAAE,IAAI,CAAC6E;IAAoB,gBAClDxQ,KAAA,CAAAmM,aAAA,CAACjM,IAAI;MAACkM,KAAK,EAAE,CAACC,MAAM,CAAC0E,oBAAoB,EAAE;QAAEG,gBAAgB,EAAE;MAAE,CAAC;IAAE,gBAClElR,KAAA,CAAAmM,aAAA,CAAC9L,IAAI;MAAC+L,KAAK,EAAE,CAACC,MAAM,CAAC4E,eAAe,EAAE;QAAElB,KAAK,EAAE,IAAI,CAACzM,KAAK,CAACmJ;MAAmB,CAAC;IAAE,GAAC,QAAY,CACzF,CACU,CACd,CACF,CACD,CAAC;EAEZ;EAEA0E,YAAYA,CAAA,EAAG;IACb,oBACEnR,KAAA,CAAAmM,aAAA,CAAC3L,KAAK;MAAC4P,OAAO;MAACC,WAAW;MAACC,aAAa,EAAC,OAAO;MAACC,cAAc,EAAE,IAAI,CAAClF;IAAW,gBAC/ErL,KAAA,CAAAmM,aAAA,CAAC9K,MAAM;MAAC+P,QAAQ,EAAC,YAAY;MAACC,WAAW,EAAE,IAAI,CAAChG,UAAW;MAACK,IAAI,EAAE,IAAI,CAACpI,KAAK,CAACgO,UAAU,IAAI;IAAe,CAAE,CAAC,eAC7GtR,KAAA,CAAAmM,aAAA,CAACjM,IAAI;MAACkM,KAAK,EAAEC,MAAM,CAACkF;IAAiB,GAClC,IAAI,CAAChE,sBAAsB,CAAC,CAAC,EAC7B,IAAI,CAACY,mBAAmB,CAAC,CAAC,EAC1B,IAAI,CAACU,aAAa,CAAC,CAChB,CAAC,EACN,IAAI,CAACc,kBAAkB,CAAC,CAAC,EACzB,IAAI,CAACQ,sBAAsB,CAAC,CACxB,CAAC;EAEZ;EAEAqB,MAAMA,CAAA,EAAG;IACP,MAAM;MAAE1E,OAAO;MAAEnD,cAAc;MAAEE,UAAU;MAAEU,WAAW;MAAET;IAAS,CAAC,GAAG,IAAI,CAACvB,KAAK;IAEjF,IAAIuE,OAAO,IAAI,IAAI,EAAE;MACnB,oBACE9M,KAAA,CAAAmM,aAAA,CAAC7K,KAAK;QACJ0C,KAAK,EAAC,qBAAqB;QAC3B0H,IAAI,EAAEoB,OAAQ;QACdrB,OAAO,EAAE,CACP;UACEC,IAAI,EAAE,gBAAgB;UACtB+F,MAAM,EAAE,IAAI,CAACpE,sBAAsB,CAACqE,IAAI,CAAC,IAAI,CAAC;UAC9CC,IAAI,EAAE;QACR,CAAC,EACD;UACEjG,IAAI,EAAE,QAAQ;UACd+F,MAAM,EAAE,IAAI,CAACrE,iBAAiB,CAACsE,IAAI,CAAC,IAAI;QAC1C,CAAC;MACD,CACH,CAAC;IAEN;IAEA,IAAI/H,cAAc,EAAE;MAClB,MAAM8B,OAAO,GAAG,IAAI,CAACmG,YAAY,CAAC,CAAC;MACnC,oBAAO5R,KAAA,CAAAmM,aAAA,CAAC5K,SAAS;QAACsQ,OAAO,EAAE,IAAI,CAACvL,cAAc,CAACoL,IAAI,CAAC,IAAI,CAAE;QAACjG,OAAO,EAAEA,OAAQ;QAACzH,KAAK,EAAE,IAAI,CAACV,KAAK,CAACgO,UAAW;QAACQ,UAAU,EAAC;MAAQ,CAAE,CAAC;IACnI;IAEA,IAAIjI,UAAU,EAAE,OAAO,IAAI,CAACsH,YAAY,CAAC,CAAC;IAE1C,IAAI5G,WAAW,EAAE;MACf,oBACEvK,KAAA,CAAAmM,aAAA,CAAC/K,oBAAoB;QACnB2Q,KAAK,EAAE;UAAEhN,GAAG,EAAE+E,QAAQ,CAAC,CAAC;QAAE,CAAE;QAC5BkI,aAAa,EAAE,IAAI,CAACC,aAAc;QAClCC,SAAS,EAAE3H,WAAY;QACvB4H,gBAAgB,EAAEvN,IAAI,IAAI;UACxB,IAAI,CAAC2E,iBAAiB,CAAC3E,IAAI,CAACG,GAAG,CAAC;QAClC;MAAE,CACH,CAAC;IAEN;IAEA,OAAO,IAAI;EACb;AACF;AAEA,MAAMsH,MAAM,GAAG3L,UAAU,CAAC0R,MAAM,CAAC;EAC/Bb,gBAAgB,EAAE;IAChBc,IAAI,EAAE,CAAC;IACP7F,eAAe,EAAE3K;EACnB,CAAC;EACDwN,gBAAgB,EAAE;IAChBiD,OAAO,EAAE;EACX,CAAC;EACD/C,aAAa,EAAE;IACb+C,OAAO,EAAE;EACX,CAAC;EACDhG,qBAAqB,EAAE;IACrB+F,IAAI,EAAE,CAAC;IACP7F,eAAe,EAAE;EACnB,CAAC;EACDD,uBAAuB,EAAE;IACvBgG,QAAQ,EAAE,UAAU;IACpBC,GAAG,EAAE,CAAC;IACNC,KAAK,EAAE,CAAC;IACRjQ,KAAK,EAAE,EAAE;IACTE,MAAM,EAAE,EAAE;IACVgQ,YAAY,EAAE,EAAE;IAChBC,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE;EAClB,CAAC;EACDlG,gBAAgB,EAAE;IAChBmG,UAAU,EAAE,aAAa;IACzBC,QAAQ,EAAE,EAAE;IACZ/C,KAAK,EAAE,MAAM;IACbgD,YAAY,EAAE;EAChB,CAAC;EACDlG,gBAAgB,EAAE;IAChBiG,QAAQ,EAAE,EAAE;IACZ/C,KAAK,EAAE,MAAM;IACbgD,YAAY,EAAE;EAChB,CAAC;EACDjD,eAAe,EAAE;IACf6C,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE,QAAQ;IACxBlQ,MAAM,EAAE,EAAE;IACVsQ,iBAAiB,EAAE,EAAE;IACrBxG,eAAe,EAAE;EACnB,CAAC;EACDkC,iBAAiB,EAAE;IACjBuE,UAAU,EAAE,EAAE;IACdD,iBAAiB,EAAE,EAAE;IACrBE,aAAa,EAAE,KAAK;IACpBP,UAAU,EAAE;EACd,CAAC;EACDhE,qBAAqB,EAAE;IACrBkE,UAAU,EAAE,WAAW;IACvBC,QAAQ,EAAE,EAAE;IACZ/C,KAAK,EAAEhO,aAAa;IACpBoR,WAAW,EAAE;EACf,CAAC;EACDvE,qBAAqB,EAAE;IACrBkE,QAAQ,EAAE,EAAE;IACZ/C,KAAK,EAAEhO;EACT,CAAC;EACD0O,gBAAgB,EAAE;IAChB8B,QAAQ,EAAE,UAAU;IACpBa,MAAM,EAAE,CAAC;IACTC,IAAI,EAAE,CAAC;IACPZ,KAAK,EAAE,CAAC;IACRD,GAAG,EAAE,CAAC;IACNhG,eAAe,EAAE,iBAAiB;IAClC8G,MAAM,EAAE;EACV,CAAC;EACD5C,oBAAoB,EAAE;IACpB6B,QAAQ,EAAE,UAAU;IACpBa,MAAM,EAAE,CAAC;IACTC,IAAI,EAAE,CAAC;IACPZ,KAAK,EAAE,CAAC;IACRjG,eAAe,EAAE,MAAM;IACvB+G,mBAAmB,EAAE,EAAE;IACvBC,oBAAoB,EAAE,EAAE;IACxBC,SAAS,EAAEhR,aAAa,GAAG;EAC7B,CAAC;EACDkO,yBAAyB,EAAE;IACzB2B,OAAO,EAAE,EAAE;IACXoB,WAAW,EAAEzR,QAAQ;IACrB0R,iBAAiB,EAAE;EACrB,CAAC;EACD/C,gBAAgB,EAAE;IAChBiC,UAAU,EAAE,aAAa;IACzBC,QAAQ,EAAE,EAAE;IACZc,SAAS,EAAE,QAAQ;IACnB7D,KAAK,EAAE/N;EACT,CAAC;EACD+O,oBAAoB,EAAE;IACpBG,gBAAgB,EAAE,EAAE;IACpB2C,eAAe,EAAE,EAAE;IACnBH,WAAW,EAAEzR,QAAQ;IACrB+O,cAAc,EAAE;EAClB,CAAC;EACDC,eAAe,EAAE;IACf4B,UAAU,EAAE,YAAY;IACxBC,QAAQ,EAAE,EAAE;IACZc,SAAS,EAAE,QAAQ;IACnB7D,KAAK,EAAE/N;EACT,CAAC;EACD2L,yBAAyB,EAAE;IACzBsF,UAAU,EAAE,EAAE;IACda,YAAY,EAAE,CAAC;IACfC,WAAW,EAAE;EACf,CAAC;EACDnG,oBAAoB,EAAE;IACpBuF,WAAW,EAAE;EACf,CAAC;EACDtF,gBAAgB,EAAE;IAChBrL,KAAK,EAAE,EAAE;IACTE,MAAM,EAAE,EAAE;IACViQ,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE,QAAQ;IACxBF,YAAY,EAAE,CAAC;IACfsB,QAAQ,EAAE;EACZ,CAAC;EACDjG,uBAAuB,EAAE;IACvBwE,QAAQ,EAAE,UAAU;IACpBC,GAAG,EAAE,CAAC,CAAC;IACPC,KAAK,EAAE,CAAC;EACV,CAAC;EACDxE,0BAA0B,EAAE;IAC1B2E,cAAc,EAAE,QAAQ;IACxBD,UAAU,EAAE,QAAQ;IACpBD,YAAY,EAAE,EAAE;IAChBlQ,KAAK,EAAE,EAAE;IACTE,MAAM,EAAE,EAAE;IACVuR,WAAW,EAAE,CAAC;IACdP,WAAW,EAAE;EACf,CAAC;EACDxF,qBAAqB,EAAE;IACrB4E,QAAQ,EAAE,EAAE;IACZ/C,KAAK,EAAE,MAAM;IACbgD,YAAY,EAAE;EAChB;AACF,CAAC,CAAC;AAEF,MAAMmB,eAAe,GAAG3L,KAAK,IAAI;EAC/B,MAAM;IAAE7D,IAAI;IAAEsG;EAAM,CAAC,GAAGzC,KAAK;EAC7B,MAAM8F,YAAY,GAAGrD,KAAK,CAACqD,YAAY,CACpC8F,MAAM,CAACC,MAAM,IAAI,CAACA,MAAM,CAACC,MAAM,CAAC,CAChC/M,GAAG,CAACiH,KAAK,IAAI;IACZ,OAAO;MACLvK,KAAK,EAAEuK,KAAK,CAAC+F,IAAI;MACjBrQ,EAAE,EAAEsK,KAAK,CAACgG,KAAK,IAAI,EAAE;MACrBC,MAAM,EAAEjG,KAAK,CAACgG,KAAK,GAAGhG,KAAK,CAACpE,MAAM,GAAGa,KAAK,CAAC1G;IAC7C,CAAC;EACH,CAAC,CAAC;EAEJ,OAAO;IACLI,IAAI;IACJ2J,YAAY;IACZ5B,kBAAkB,EAAE7K,8BAA8B,CAAC2G,KAAK;EAC1D,CAAC;AACH,CAAC;AAED,eAAe3H,OAAO,CAACsT,eAAe,EAAE;EAAE9R,iBAAiB;EAAEC;AAAmB,CAAC,EAAE,IAAI,EAAE;EAAEoS,UAAU,EAAE;AAAK,CAAC,CAAC,CAACrR,aAAa,CAAC","ignoreList":[]}
@@ -16,7 +16,12 @@ const CoreConfig = {
16
16
  preferredSite: '',
17
17
  strings: {},
18
18
  newEventDefaults: '',
19
- defaultAllowComments: true
19
+ defaultAllowComments: true,
20
+ AuthStrategy: {
21
+ getAccessToken: async () => null,
22
+ getCurrentUserId: async () => null,
23
+ hasActiveSession: async () => false
24
+ }
20
25
  },
21
26
  init: (environment, navigation) => {
22
27
  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","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":[]}
1
+ {"version":3,"names":["Services","navigation","CoreConfig","env","baseStage","baseAPIUrl","hasGradientHeader","defaultProfileImage","tinyChatDefault","baseUploadsUrl","allowMediaDownload","allowMediaSharing","awsUploadsBucket","awsStorageBucket","preferredSite","strings","newEventDefaults","defaultAllowComments","AuthStrategy","getAccessToken","getCurrentUserId","hasActiveSession","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 AuthStrategy: {\n getAccessToken: async () => null,\n getCurrentUserId: async () => null,\n hasActiveSession: async () => false,\n },\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,IAAI;IAC1BC,YAAY,EAAE;MACZC,cAAc,EAAE,MAAAA,CAAA,KAAY,IAAI;MAChCC,gBAAgB,EAAE,MAAAA,CAAA,KAAY,IAAI;MAClCC,gBAAgB,EAAE,MAAAA,CAAA,KAAY;IAChC;EACF,CAAC;EACDC,IAAI,EAAEA,CAACC,WAAW,EAAEtB,UAAU,KAAK;IACjCC,UAAU,CAACC,GAAG,GAAGoB,WAAW;IAC5BvB,QAAQ,CAACC,UAAU,GAAGA,UAAU;EAClC;AACF,CAAC;AACD,eAAeC,UAAU","ignoreList":[]}
@@ -1,4 +1,4 @@
1
- import { createIconSetFromIcoMoon } from '@expo/vector-icons';
1
+ import createIconSetFromIcoMoon from '@expo/vector-icons/createIconSetFromIcoMoon';
2
2
  import icoMoonConfig from './pluss60-icons.json';
3
3
  const Pl60Icon = createIconSetFromIcoMoon(icoMoonConfig, 'pluss60-icons');
4
4
  export { Pl60Icon };
@@ -1 +1 @@
1
- {"version":3,"names":["createIconSetFromIcoMoon","icoMoonConfig","Pl60Icon"],"sources":["pluss60-icons.js"],"sourcesContent":["import { createIconSetFromIcoMoon } from '@expo/vector-icons';\nimport icoMoonConfig from './pluss60-icons.json';\n\nconst Pl60Icon = createIconSetFromIcoMoon(icoMoonConfig, 'pluss60-icons');\n\nexport { Pl60Icon };\n"],"mappings":"AAAA,SAASA,wBAAwB,QAAQ,oBAAoB;AAC7D,OAAOC,aAAa,MAAM,sBAAsB;AAEhD,MAAMC,QAAQ,GAAGF,wBAAwB,CAACC,aAAa,EAAE,eAAe,CAAC;AAEzE,SAASC,QAAQ","ignoreList":[]}
1
+ {"version":3,"names":["createIconSetFromIcoMoon","icoMoonConfig","Pl60Icon"],"sources":["pluss60-icons.js"],"sourcesContent":["import createIconSetFromIcoMoon from '@expo/vector-icons/createIconSetFromIcoMoon';\n\nimport icoMoonConfig from './pluss60-icons.json';\n\nconst Pl60Icon = createIconSetFromIcoMoon(icoMoonConfig, 'pluss60-icons');\n\nexport { Pl60Icon };\n"],"mappings":"AAAA,OAAOA,wBAAwB,MAAM,6CAA6C;AAElF,OAAOC,aAAa,MAAM,sBAAsB;AAEhD,MAAMC,QAAQ,GAAGF,wBAAwB,CAACC,aAAa,EAAE,eAAe,CAAC;AAEzE,SAASC,QAAQ","ignoreList":[]}
@@ -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';
4
5
  export const getSessionTokenAWS = async prefix => {
5
- const data = await Auth.currentSession();
6
- const token = data.accessToken.jwtToken;
6
+ const token = await Config.env.AuthStrategy.getAccessToken();
7
7
  if (_.isUndefined(prefix)) return token;
8
8
  return `${prefix} ${token}`;
9
9
  };
@@ -1 +1 @@
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":[]}
1
+ {"version":3,"names":["_","axios","Auth","Config","getSessionTokenAWS","prefix","token","env","AuthStrategy","getAccessToken","isUndefined","getSessionUidAWS","Promise","resolve","reject","currentSession","then","data","accessToken","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';\nimport Config from './config';\n\nexport const getSessionTokenAWS = async prefix => {\n const token = await Config.env.AuthStrategy.getAccessToken();\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;AAClC,OAAOC,MAAM,MAAM,UAAU;AAE7B,OAAO,MAAMC,kBAAkB,GAAG,MAAMC,MAAM,IAAI;EAChD,MAAMC,KAAK,GAAG,MAAMH,MAAM,CAACI,GAAG,CAACC,YAAY,CAACC,cAAc,CAAC,CAAC;EAC5D,IAAIT,CAAC,CAACU,WAAW,CAACL,MAAM,CAAC,EAAE,OAAOC,KAAK;EACvC,OAAO,GAAGD,MAAM,IAAIC,KAAK,EAAE;AAC7B,CAAC;;AAED;AACA;AACA;AACA;;AAEA,OAAO,MAAMK,gBAAgB,GAAGA,CAAA,KAAM;EACpC,OAAO,IAAIC,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;IACtCZ,IAAI,CAACa,cAAc,CAAC,CAAC,CAClBC,IAAI,CAACC,IAAI,IAAI;MACZJ,OAAO,CAACI,IAAI,CAACC,WAAW,CAACC,OAAO,CAACC,QAAQ,CAAC;IAC5C,CAAC,CAAC,CACDC,KAAK,CAACC,GAAG,IAAI;MACZC,OAAO,CAACC,GAAG,CAAC,wBAAwB,EAAEF,GAAG,CAAC;MAC1CR,MAAM,CAACQ,GAAG,CAAC;IACb,CAAC,CAAC;EACN,CAAC,CAAC;AACJ,CAAC;AAED,OAAO,MAAMG,cAAc,GAAG,MAAMC,OAAO,IAAI;EAC7C,MAAMC,OAAO,GAAG,MAAMvB,kBAAkB,CAAC,CAAC;EAC1C,IAAI,CAACsB,OAAO,CAACE,OAAO,EAAEF,OAAO,CAACE,OAAO,GAAG,CAAC,CAAC;EAC1CF,OAAO,CAACE,OAAO,CAACD,OAAO,GAAGA,OAAO;EAEjC,OAAO1B,KAAK,CAACyB,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,CAAChB,IAAI;IACrC,OAAOe,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": "7.0.0-beta.2",
3
+ "version": "7.0.1-auth.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,6 +15,9 @@
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",
18
21
  "upload": "npm run build && npm publish --access public",
19
22
  "upload:p": "npm run patch && npm run upload"
20
23
  },
@@ -22,7 +25,7 @@
22
25
  "license": "ISC",
23
26
  "dependencies": {},
24
27
  "peerDependencies": {
25
- "@expo/vector-icons": "^14.0.0",
28
+ "@expo/vector-icons": "^14.1.0",
26
29
  "@react-native-async-storage/async-storage": "^1.23.1",
27
30
  "aws-amplify": "^4.3.11",
28
31
  "aws-amplify-react-native": "^6.0.2",
@@ -67,4 +70,4 @@
67
70
  "module"
68
71
  ]
69
72
  }
70
- }
73
+ }
@@ -1,41 +1,34 @@
1
- import mime from 'mime-types';
2
- import { Storage } from 'aws-amplify';
1
+ import Axios from 'axios';
3
2
  import { getUrl, generateImageName, randomString } from '../helper';
4
3
  import { authedFunction } from '../session';
5
- import Config from '../config';
6
4
 
7
5
  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
+ },
8
14
  getUploadUrl: (userId, fileName) => {
9
15
  const newFilename = fileName.replace(/[^a-z0-9+.]+/gi, '').toLowerCase();
10
16
  return `uploads/users/${userId}/public/${randomString()}/${newFilename}`;
11
17
  },
12
- uploadUserMediaWithProgress: async (imageUri, url, progressCallback = null) => {
13
- const blob = await fileActions.imageToBlob(imageUri);
14
- return fileActions.uploadBlobAWS(Config.env.awsUploadsBucket, url, blob, '', progressCallback);
18
+ uploadUserMediaWithProgress: async (blob, url, progressCallback = null) => {
19
+ return fileActions.uploadBlobAWS(url, blob, progressCallback);
15
20
  },
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
- // },
26
21
  imageToBlob: async imageUri => {
27
22
  const response = await fetch(imageUri);
28
23
  return response.blob();
29
24
  },
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 =>
25
+ uploadBlobAWS: async (uri, blob, progressCallback = null) => {
26
+ return Axios.put(uri, blob, {
27
+ headers: {
28
+ 'Content-Type': blob.type,
29
+ },
30
+ transformRequest: d => d,
31
+ onUploadProgress: progress =>
39
32
  progressCallback &&
40
33
  progressCallback({
41
34
  uri,
@@ -43,8 +36,7 @@ export const fileActions = {
43
36
  total: progress.total,
44
37
  percentage: `${Math.floor((progress.loaded / progress.total) * 100)}%`,
45
38
  }),
46
- };
47
- return Storage.put(`${prefix}${imageName}`, blob, access);
39
+ });
48
40
  },
49
41
  getStockPhotos: async () => {
50
42
  const response = await authedFunction({
@@ -60,16 +60,8 @@ class ImageUploader extends Component {
60
60
  }
61
61
 
62
62
  loadLocalAlbums = async () => {
63
- const { status: existingStatus } = await MediaLibrary.getPermissionsAsync();
64
- let status = existingStatus;
65
- if (status !== 'granted') {
66
- const { status: newStatus } = await MediaLibrary.requestPermissionsAsync();
67
- status = newStatus;
68
- }
69
- if (status !== 'granted') {
70
- console.warn('MediaLibrary permission not granted');
71
- return;
72
- }
63
+ const hasPermission = await MediaLibrary.getPermissionsAsync();
64
+ if (!hasPermission.granted) return;
73
65
 
74
66
  this.setState({ loadingLocalFolders: true }, async () => {
75
67
  try {
@@ -150,23 +142,25 @@ class ImageUploader extends Component {
150
142
  let uploadUri;
151
143
  try {
152
144
  const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;
153
- uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
154
145
 
155
- this.props.onUploadStarted(uploadUri, imageUri);
156
146
  this.hideUploadMenu();
157
147
 
158
148
  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);
159
153
  if (this.props.onlySelectImage) {
160
154
  this.props.onImageSelected(resized, fileName);
161
155
  return;
162
156
  }
163
157
 
164
- const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {
158
+ const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {
165
159
  if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
166
160
  });
167
161
 
168
- this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
169
- console.log('upload success', Config.env.baseUploadsUrl + res.key);
162
+ this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);
163
+ console.log('upload success', Config.env.baseUploadsUrl + uploadUri);
170
164
  } catch (e) {
171
165
  console.log('handleImagePicked error', e);
172
166
  this.props.onUploadFailed(uploadUri);
@@ -178,7 +172,6 @@ class ImageUploader extends Component {
178
172
  const imagesUploaded = imagesSelected.map(image => {
179
173
  const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_IMAGE_NAME)}.${DEFULAT_IMAGE_TYPE}`;
180
174
  const uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
181
- if (!this.props.onlySelectImage) this.props.onUploadStarted(uploadUri, image.uri);
182
175
  return { imageUri: image.uri, uploadUri, fileName };
183
176
  });
184
177
  this.hideUploadMenu();
@@ -189,16 +182,21 @@ class ImageUploader extends Component {
189
182
  const { imageUri, uploadUri, fileName } = image;
190
183
  try {
191
184
  const resized = await this.resizeImageAsync(imageUri);
185
+ const blob = await fileActions.imageToBlob(resized.uri);
192
186
  if (this.props.onlySelectImage) {
193
187
  this.props.onImageSelected(resized, fileName);
194
188
  return;
195
189
  }
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);
196
193
 
197
- const res = await fileActions.uploadUserMediaWithProgress(resized.uri, uploadUri, progress => {
194
+ const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {
198
195
  if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
199
196
  });
200
- this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
201
- console.log('upload success', Config.env.baseUploadsUrl + res.key);
197
+
198
+ this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);
199
+ console.log('upload success', Config.env.baseUploadsUrl + uploadUri);
202
200
  } catch (e) {
203
201
  console.log('handleMultiImagePicked error', e);
204
202
  this.props.onUploadFailed(uploadUri);
@@ -211,17 +209,19 @@ class ImageUploader extends Component {
211
209
  try {
212
210
  const fileType = uri.substring(uri.lastIndexOf('.') + 1);
213
211
  const fileName = `${getValueOrDefault(this.props.fileName, DEFAULT_VIDEO_NAME)}.${fileType}`;
214
- uploadUri = fileActions.getUploadUrl(this.props.userId, fileName);
212
+ const blob = await fileActions.imageToBlob(uri);
213
+ const presignedUriRes = await fileActions.getPresignedUrl(fileName, blob.type);
214
+ uploadUri = presignedUriRes.key;
215
215
 
216
216
  this.props.onUploadStarted(uploadUri, uri);
217
217
  this.hideUploadMenu();
218
218
 
219
- const res = await fileActions.uploadUserMediaWithProgress(uri, uploadUri, progress => {
219
+ const uploadResult = await fileActions.uploadUserMediaWithProgress(blob, presignedUriRes.url, progress => {
220
220
  if (this.props.onUploadProgress) this.props.onUploadProgress(progress);
221
221
  });
222
222
 
223
- this.props.onUploadSuccess(Config.env.baseUploadsUrl + res.key, uploadUri);
224
- console.log('upload success', Config.env.baseUploadsUrl + res.key);
223
+ this.props.onUploadSuccess(Config.env.baseUploadsUrl + uploadUri, uploadUri);
224
+ console.log('upload success', Config.env.baseUploadsUrl + uploadUri);
225
225
  } catch (e) {
226
226
  console.log('handleVideoPicked error', e);
227
227
  this.props.onUploadFailed(uploadUri);
@@ -274,6 +274,7 @@ class ImageUploader extends Component {
274
274
  };
275
275
 
276
276
  isEditingEnabled = () => {
277
+ return false;
277
278
  return !this.props.multiple && !this.props.allowVideo && getValueOrDefault(this.props.allowsEditing, DEFAULT_ALLOWS_EDITING);
278
279
  };
279
280
 
@@ -312,13 +313,21 @@ class ImageUploader extends Component {
312
313
  };
313
314
 
314
315
  openLibrary = async () => {
315
- this.setState({
316
- showUploadMenu: false,
317
- showPhotos: true,
318
- selected: [],
319
- showRemote: true,
320
- selectedAlbumId: '',
321
- });
316
+ this.setState(
317
+ {
318
+ showUploadMenu: false,
319
+ },
320
+ () => {
321
+ setTimeout(() => {
322
+ this.setState({
323
+ showPhotos: true,
324
+ selected: [],
325
+ showRemote: true,
326
+ selectedAlbumId: '',
327
+ });
328
+ }, 1000);
329
+ },
330
+ );
322
331
  };
323
332
 
324
333
  openPhotos = async () => {
@@ -342,13 +351,21 @@ class ImageUploader extends Component {
342
351
  // iOS behaviour
343
352
  if (!(await this.askPermissionsAsync())) return;
344
353
 
345
- this.setState({
346
- showUploadMenu: false,
347
- showPhotos: true,
348
- selected: [],
349
- showRemote: false,
350
- selectedAlbumId: '',
351
- });
354
+ this.setState(
355
+ {
356
+ showUploadMenu: false,
357
+ },
358
+ () => {
359
+ setTimeout(() => {
360
+ this.setState({
361
+ showPhotos: true,
362
+ selected: [],
363
+ showRemote: false,
364
+ selectedAlbumId: '',
365
+ });
366
+ }, 1000);
367
+ },
368
+ );
352
369
  };
353
370
 
354
371
  hidePhotos = () => {
@@ -398,6 +415,7 @@ class ImageUploader extends Component {
398
415
  } else {
399
416
  if (mediaSelected[0].mediaType === MediaLibrary.MediaType.video) {
400
417
  const uri = mediaSelected[0].localUri || mediaSelected[0].uri;
418
+ console.log('picked a video');
401
419
  this.handleVideoPicked(uri);
402
420
  } else {
403
421
  this.handleMultiImagePicked(mediaSelected);
package/src/config.js CHANGED
@@ -18,6 +18,11 @@ 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
+ },
21
26
  },
22
27
  init: (environment, navigation) => {
23
28
  CoreConfig.env = environment;
@@ -1,4 +1,5 @@
1
- import { createIconSetFromIcoMoon } from '@expo/vector-icons';
1
+ import createIconSetFromIcoMoon from '@expo/vector-icons/createIconSetFromIcoMoon';
2
+
2
3
  import icoMoonConfig from './pluss60-icons.json';
3
4
 
4
5
  const Pl60Icon = createIconSetFromIcoMoon(icoMoonConfig, 'pluss60-icons');
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';
4
5
 
5
6
  export const getSessionTokenAWS = async prefix => {
6
- const data = await Auth.currentSession();
7
- const token = data.accessToken.jwtToken;
7
+ const token = await Config.env.AuthStrategy.getAccessToken();
8
8
  if (_.isUndefined(prefix)) return token;
9
9
  return `${prefix} ${token}`;
10
10
  };