Как ты себе это представляешь?
первое что в голову пришло return yield call(api, ... но это ведь генератор
Куда ретурн? Ты совсем не понимаешь разницу?
😆
да, я спрашивал есть какие то обходные варианты передать промис рендеру, чтобы например при получении данных что то отобразить?
Какой промис?
которого нет в саге))
В какой именно саге?
внутри воркера. молодец хорошие вопросы😆
Какого из воркеров?
который запускается при takeEvery(actionType, worker)
new Promise((resolve, reject) => { dispatch(foo(resolve, reject)) }).then(...).catch(...) Ты что-то вроде этого хочешь сделать?
takeEvery(actionType, worker) takeEvery(actionType, worker2)
Какого из них?
ааа да. создавать тогда эту функцию с промисом в action.js ? и запускать сагу там?
yield takeEvery(actionType.TOGGLE_2STEP, toggle2step) function* toggle2step(action: Toggle2step): Generator { try { yield call(api, { method: 'POST', url: '/auth/set2FA', body: { twoFACode: action.code, is2FA: action.status } }) yield put(showSnackbar('success')) } catch (e) { yield put(showSnackbar('error', e.message)) } }
yield takeEvery( actionType.TOGGLE_2STEP, toggle2step ) yield takeEvery( actionType.TOGGLE_2STEP, doSomethingElse )
типа внутри вотчера поместить вторую функцию? export function* watchUser() { yield takeEvery(actionType.GET_USER, getUser) yield takeEvery(actionType.TOGGLE_2STEP, toggle2step) yield takeEvery(actionType.TOGGLE_2STEP, doAsyncFunc) yield takeEvery(actionType.GENERATE_QR, generateQr) }
Забей. Просто забей. Ты вечность копаешься с сагами и даже не попытался вникнуть в суть механизма. Грустно. Если бы чучуть подумал, как они работают, то понял бы ответ на твой вопрос — НЕТ, НЕЛЬЗЯ из саги промис в диспатч вернуть.
ну так я понял, нужно в вотчере запускать асинхронку отдельно
я просто перенес большинство логики прямиком в сагу yield put(updateUser(actionType, payload))
Обсуждают сегодня