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

for loop in javascript - promise - .eslintrc for "for of"

the vast majority of cases  map ,  forEach ,  find  etc. can be used.  async function printFiles () { const files = await getFilePaths(); await Promise.all(files. map (async (file) => { const contents = await fs.readFile(file, 'utf8') console.log(contents) })); } const inventory = [ { name : 'apples' , quantity : 2 } , { name : 'bananas' , quantity : 0 } , { name : 'cherries' , quantity : 5 } ] ; const result = inventory . find ( ( { name } ) => name === 'cherries' ) ;   function getFirstMatching(array) { for (let item of array) { const result = heavyTransform(item); if (result) { return result; } } } Specifically this shuts down the whole no-restricted-syntax. If you want to cherry-pick, here is the current definition: 'no-restricted-syntax' : [ 'error' , { selector : 'ForInStatement' , message...

Apollo client - cache APIs - auto update cache - erase cache - reactive variables - deletion - addition

Apollo Client 3  Local only fields Reactive Variables const cache = new InMemoryCache ( { typePolicies : { Todo : { // If one of the keyFields is an object with fields of its own, you can // include those nested keyFields by using a nested array of strings: keyFields : [ "date" , "user" , [ "email" ] ] , } } , } ) ; This internal data is intended to be easily  JSON-serializable , so you can take a snapshot with  cache.extract() , save it somewhere, and later restore with  cache.restore(snapshot) . Here’s a mutation called  EditTodo  that returns the new  todo  value in the mutation response. mutation EditTodo ( $id : Int ! , $text : String ! ) { editTodo ( id : $id , text : $text ) { success todo { # <- Returning it here id text completed } error { ... on TodoNotFoundError { message } ... on TodoValidationE...

window.URL.createObjectURL is not (yet) available in jest-dom - testing scenario

Since  window.URL.createObjectURL  is not (yet) available in jest-dom, you need to provide a mock implementation for it. Don't forget to reset the mock implementation after each test. describe ( "your test suite" , () => { window . URL . createObjectURL = jest . fn (); afterEach (() => { window . URL . createObjectURL . mockReset (); }); it ( "your test case" , () => { expect ( true ). toBeTruthy (); }); });