Задать вопрос
@Levingstoun

Как правильно удалить сообщения в react-redux & hook?

Пытаюсь удалить сообщение, которое приходит в пропсах. Использую хуки и редакс. Почему-то метод splice удаляет не по одному сообщению, а все, которые я бы отправил.
Как сделать правильно?
const ProfilePost = (props) => {
  let [editMode, setEditMode] = useState(false);
  let [messages, setMessages] = useState([props.message]);
  let [post, setStatePost] = useState([props.posts]);

 useEffect(() => {
    setMessages(messages);
  }, [messages]);


  const activateEditMode = () => {
    setEditMode(true);
  };

  const deactivateEditMode = (messages) => {
    setEditMode(false);
    props.updateMessage(messages);
  };

  const onMessageChange = (e) => {
    setMessages(e.currentTarget.value);
  };
  

  const deleteMode = () => {
   props.deletePost()
  }

  return (
    <div>
    <div>
    {post.map((element, i) => (
      <div className={style.message} id={i}>
        {!editMode && (
         <div>
          <div>
            <span></span>
            </div>
     <div className={style.message_wrapper}>
        <div>
          <span className={style.field_message}>
            {props.message}
          </span>
          <div>
            <button onClick={activateEditMode}>
              edit message
            </button>
          </div>
              <div>
            <button className={style.button_delete} onClick={() => deleteMode()}>
              delete
            </button>
          </div>
        </div>
        </div>
       </div>
      )}

      {editMode && (
      	<div>
            <span></span>
          <TextareaAutosize
            className={style.field_edit}
            onChange={onMessageChange}
           value={props.message}
          />
          <div>
            <button onClick={deactivateEditMode}>
              save
            </button>
          </div>
        </div>
      )}
          </div>
          ))}
              </div>
    </div>
  )
}

let mapStateToProps = state => {
  return {
    newPostText: state.profilePage.newPostText,
    posts: state.profilePage.posts,
  };
};

let mapDispatchToProps = dispatch => {
  return {
    updateMessage: (message) => {
      let action = updateMessage(message);
      dispatch(action);
    },
    deletePost: () => {
      let action = deletePost();
      dispatch(action);
    },
  };
};

const ProfilePostEdit = connect(
  mapStateToProps,
  mapDispatchToProps
)(ProfilePost);


Кусок редьюсера

const DELETE_POST = 'DELETE_POST'

let initialState = {
  profile: null,
  posts: []
}
const profileReducer = (state = initialState, action) => {
  switch (action.type) {
  case DELETE_POST: {
      return { ...state, posts: state.posts.splice(0, 1)}
    }
}
export const deletePost = (key) => ({type: DELETE_POST, key})
};
}
  • Вопрос задан
  • 439 просмотров
Подписаться 1 Средний Комментировать
Пригласить эксперта
Ответы на вопрос 2
@Dasslier
FrontEnd Developer
Немного непонятно. Это весь код редьюсера? Если весь - то он у вас вообще пустой, вы пытаетесь вырезать элемент из пустого массива.
Ответ написан
hzzzzl
@hzzzzl
export const deletePost = (key) => ({type: DELETE_POST, key})

этот key это айдишник поста в массиве с постами? или где он используется?

switch (action.type) {
  case DELETE_POST: {
      // action.key = post_id  который надо удалить
      return { 
        ...state, 
        posts: state.posts.filter(post => post.key !== action.key)
      }
    }
}

ну и в шаблоне вызывать как
props.deletePost(айдиПоста)
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
18 янв. 2025, в 10:04
50000 руб./за проект
18 янв. 2025, в 09:18
5500 руб./за проект
18 янв. 2025, в 07:20
50000 руб./за проект