Skip to main content

upload to storage with promise (helper) instead of hook (useUploadStorage)

export const uploadFileToStorage = async (
foldName: string,
dataUrl: string
) => {
return new Promise((resolve, reject) => {
const timestamp = Number(new Date())
const fileName = `/documents/${foldName}-${timestamp.toString()}`

const storageRef = firebaseApp.storage().ref(fileName)
const uploadTask = storageRef.putString(dataUrl, 'data_url')
uploadTask.on(
firebaseApp.storage.TaskEvent.STATE_CHANGED,
snapshot => {},
error => {
reject(error.message)
},
() => {
storageRef.getDownloadURL().then(url => {
resolve(url)
})
}
)
})
}



onSubmit={(values, { setSubmitting, resetForm }) => {
setMessage(i18next.t('PROCESSING'))
const copy = { ...values }
await Promise.all(
inputFieldsForAdditionalForm
.filter(field => field.type === 'file')
.map(async field => {
const dataUrl = values[field.name]
const url = await uploadFileToStorage(
'additionalForms',
dataUrl
)
copy[field.name] = url
})
)


 import React, { useEffect, useState } from 'react'

import { firebaseApp } from '../../lib/firebase'

function useUploadStorage(
foldName: string,
dataUrl: string
): [string, boolean, string] {
const [message, setMessage] = useState('')
const [loading, setLoading] = useState(false)
const [sigUrl, setSigUrl] = useState('')

useEffect(() => {
const upload = () => {
const timestamp = Number(new Date())
const fileName = `/documents/${foldName}-${timestamp.toString()}`

const storageRef = firebaseApp.storage().ref(fileName)
const uploadTask = storageRef.putString(dataUrl, 'data_url')
uploadTask.on(
firebaseApp.storage.TaskEvent.STATE_CHANGED,
snapshot => {
setLoading(true)
},
error => {
setMessage(error.message)
},
() => {
storageRef.getDownloadURL().then(url => {
setSigUrl(url)
setMessage('')
setLoading(false)
})
}
)
}

if (dataUrl) upload()
return () => {}
}, [dataUrl, foldName])

return [sigUrl, loading, message]
}

export default useUploadStorage


Comments

Popular posts from this blog

fs.writeFile - permission issue on GCP (Google Cloud Run)

error on this: fs . writeFile ( fileName , pdfBytes , err => { if ( err ) { console . log ( err . message ) reject ( err . message ) } else resolve ( fileName ) }) #1 It looks like when deployed into Cloud Run it also requires the extra permission "Service Account Token Creator" to run  getSignedUrl . Locally for some reason this role is not required. #2 Only the directory  /tmp  is writable in Cloud Run. So, change the default write location to write into this directory. However, you have to be aware of 2 things: Cloud Run is stateless, that means when a new instance is created, the container start from scratch, with an empty  /tmp  directory /tmp  directory is an in-memory file system. The maximum allowed memory on Cloud Run is 2Gb, your app memory footprint included. In addition of your file and Airflow, not sure that you will have a lot of space. A final remark. Cloud Run is active only when it...

A component is changing an uncontrolled input of type text to be controlled error in ReactJS - Formik

 https://stackoverflow.com/questions/47012169/a-component-is-changing-an-uncontrolled-input-of-type-text-to-be-controlled-erro default value can't be undefined  case 'listingBrokerOfficeName' : value = ( listingBroker || {}). officeName break change to: case 'listingBrokerOfficeName' : value = ( listingBroker || {}). officeName || '' break

add new site to Vagrant Homestead

Homestead.yaml: folders : - map : ~/ freshinup to : / home / vagrant / code sites : - map : smartmotors . local . com to : / home / vagrant / code / smartmotors / public php : "7.3" - map : arbor . test to : / home / vagrant / code / arbor / public php : "7.3" /etc/hosts: 192.168.10.10 arbor.test 192.168.10.10 smartmotors.local.com vagrant up --provision php artisan smartmotors:seed --quickstart