-
Notifications
You must be signed in to change notification settings - Fork 1
/
sagas.ts
105 lines (90 loc) · 3.68 KB
/
sagas.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
import { all, call, fork, put, take, putResolve, takeEvery, takeLatest, select } from 'redux-saga/effects';
interface actionObj {
type: string,
[key: string]: any
}
const delay = (ms: number) => {
return new Promise((resolve) => {
setTimeout(() => resolve(), ms);
});
};
const fetchData = (ms: number, action: actionObj) => (dispatch: (action: actionObj) => void) =>
new Promise((resolve) => {
setTimeout(function () {
dispatch(action);
resolve(action.count);
}, ms);
});
const fetchData2 = (ms: number, action: actionObj) =>
new Promise<string>((resolve) => {
setTimeout(() => {
resolve(action.count);
}, ms);
});
const fetchData3 = async (limit: number) => {
const data = await fetch(`https://jsonplaceholder.typicode.com/posts?_limit=${limit}`);
await delay(3000);
return await data.json();
};
// worker Saga: будет запускаться на экшены типа `USER_FETCH_REQUESTED`
function* setCount(action: actionObj) {
try {
if(action.data.async){
const data = yield call(fetchData2, 3000, {type: 'ASYNC_SAGA', count: action.data.count});
// const data = yield call(fetchData3,10);
// const data = yield putResolve<any>(fetchData(3000, {type: 'ASYNC_SAGA', count: action.data.count}));
// const forkEffect = yield fork(fetchData2, 3000, {type: 'ASYNC_SAGA', count: action.data.count});
yield put({type: 'RESET_PROP'});
// const asyncFetchCount = yield call(fetchData2, 3000, {type: 'ASYNC_SAGA', count: action.data.count});
// yield put({type: 'ASYNC_SAGA', count: asyncFetchCount});
const asyncCount = yield select((state) => state.asyncDataSaga.asyncCount);
console.log('ASYNC_SAGA', asyncCount);
} else {
const putEffect = yield put({type: 'NOT_ASYNC_SAGA', count: action.data.count});
const notAsyncCount = yield select((state) => state.asyncDataSaga.notAsyncCount);
console.log('NOT_ASYNC_SAGA', notAsyncCount);
}
} catch (e) {
console.log(e.message);
}
}
function* setCount2() {
while(true){
const takeEffect = yield take('*');
console.log(takeEffect);
}
}
function* mySaga() {
yield all([
fork(mySagaHelper),
// fork(setCount2)
])
}
//
// export default function* rootSaga() {
// yield takeEvery("PUT", function*() {
// yield put(fetchSmth("foo"));
// console.log("state after PUT", yield select());
// });
// yield takeEvery("PUT_RESOLVE", function*() {
// yield putResolve(fetchSmth("bar"));
// console.log("state after PUT_RESOLVE", yield select());
// });
// }
/*
Запускаем `fetchUser` на каждый задиспатченый экшен `USER_FETCH_REQUESTED`.
Позволяет одновременно получать данные пользователей.
*/
function* mySagaHelper() {
yield takeEvery("SAGA_REQUEST", setCount);
}
/*
В качестве альтернативы вы можете использовать `takeLatest`.
Не допускает одновременное получение данных пользователей. Если `USER_FETCH_REQUESTED`
диспатчится в то время когда предыдущий запрос все еще находится в ожидании ответа,
то этот ожидающий ответа запрос отменяется и срабатывает только последний.
*/
// function* mySaga() {
// yield takeLatest("USER_FETCH_REQUESTED", fetchUser);
// }
export default mySaga;