Rails + Redux-saga+Redux-FormでTodoリストを実装してみた
こちらの記事を参考に、Redux-sagaの実装を進めていたのですが、こちらはTypeScriptでは書かれていなかったので、順番に型を定義していきました。
しかし、記事の中の、以下の部分の型定義がわからずに丸2日悩んでいます。
記事を探したのですが、その部分だけ同じようなパターンがなく解決できませんでした、、
src/sagas/Post.tsx
tsx
1import { put, call } from 'redux-saga/effects'; 2import { 3 succeededFetch, 4 failedFetch, 5 succeededCreate, 6 failedCreate, 7 succeededDelete, 8 failedDelete, 9 requestDelete, 10} from '../actions'; 11import { fetchPostData } from './Api/FetchPostData'; 12import { deletePostData } from './Api/DeletePostData'; 13import { createPostData } from './Api/CreatePostData'; 14 15export function* fetchData() { 16 try { 17 const payload = yield call(fetchPostData); 18 yield put(succeededFetch(payload)); 19 } catch (e) { 20 yield put(failedFetch(e.message)); 21 } 22} 23 24export function* deleteData(action) { 25 const postId = action.data; 26 const responseData = yield call(deletePostData, postId); 27 if (responseData) { 28 yield put(succeededDelete(responseData.data)); 29 } else { 30 yield put(failedDelete('エラー')); 31 } 32} 33 34export function* createData(action) { 35 const textData = action.PostText.location; 36 const responseData = yield call(createPostData, textData); 37 if (responseData) { 38 yield put(succeededCreate(responseData.data)); 39 } else { 40 yield put(failedCreate('エラー')); 41 } 42} 43
こちらのファイルの中の、
export function* deleteData(action) {
export function* createData(action) {
の部分だけ、actionにどんな型をつければいいのかがわかりませんでした。
こういった時に、どのように考えればいいのか教えて頂けると嬉しいです。
あなたの回答
tips
プレビュー