From 49c2a86ade24ef5eb9028a3132baadf6361dae29 Mon Sep 17 00:00:00 2001 From: PetoMPP Date: Tue, 26 Dec 2023 10:41:58 +0100 Subject: [PATCH] fix #33: use editor state to tell if delete button should be rendered --- .../organisms/editor/atoms/delete_button.rs | 23 +++++++++++-------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/src/components/organisms/editor/atoms/delete_button.rs b/src/components/organisms/editor/atoms/delete_button.rs index 62e44b5..9ea4237 100644 --- a/src/components/organisms/editor/atoms/delete_button.rs +++ b/src/components/organisms/editor/atoms/delete_button.rs @@ -1,5 +1,5 @@ use crate::{ - api::client::ApiClient, + api::client::{ApiClient, RequestError}, async_event, components::atoms::modal::{show_modal_callback, Buttons, ModalButton, ModalData, ModalStore}, data::{ @@ -21,12 +21,21 @@ pub fn delete_button(props: &EditorProps) -> Html { let (locales_store, _) = use_store::(); let (_, modal_dispatch) = use_store::(); let navigator = use_navigator().unwrap(); - let err = use_state(|| None); + let err = use_state(|| Option::::None); + if let Some(e) = &*err { + if let Err(redirect) = e.handle_failed_auth(session_dispatch) { + return redirect; + } + gloo::dialogs::alert(e.to_string().as_str()); + } let (Some(resid), Some(lang)) = (&props.resid, &props.lang) else { return html! {}; }; - if let EditorState::Loading = &props.state { - return html! {}; + match &props.state { + EditorState::Loading + | EditorState::Ok(None) + | EditorState::Ok(Some((Some(true), _, _))) => return Html::default(), + _ => {} } let onstatechange = &props.onstatechanged; let token = session_store.token.clone().unwrap_or_default(); @@ -54,12 +63,6 @@ pub fn delete_button(props: &EditorProps) -> Html { }, modal_dispatch.clone(), ); - if let Some(e) = &*err { - if let Err(redirect) = e.handle_failed_auth(session_dispatch) { - return redirect; - } - gloo::dialogs::alert(e.to_string().as_str()); - } html! { }