use crate::infra::{ common_component::{CommonComponent, CommonComponentParts}, modal::Modal, }; use anyhow::{Error, Result}; use graphql_client::GraphQLQuery; use yew::prelude::*; #[derive(GraphQLQuery)] #[graphql( schema_path = "../schema.graphql", query_path = "queries/delete_user.graphql", response_derives = "Debug", custom_scalars_module = "crate::infra::graphql" )] pub struct DeleteUserQuery; pub struct DeleteUser { common: CommonComponentParts, node_ref: NodeRef, modal: Option, } #[derive(yew::Properties, Clone, PartialEq, Debug)] pub struct DeleteUserProps { pub username: String, pub on_user_deleted: Callback, pub on_error: Callback, } pub enum Msg { ClickedDeleteUser, ConfirmDeleteUser, DismissModal, DeleteUserResponse(Result), } impl CommonComponent for DeleteUser { fn handle_msg( &mut self, ctx: &Context, msg: ::Message, ) -> Result { match msg { Msg::ClickedDeleteUser => { self.modal.as_ref().expect("modal not initialized").show(); } Msg::ConfirmDeleteUser => { self.update(ctx, Msg::DismissModal); self.common.call_graphql::( ctx, delete_user_query::Variables { user: ctx.props().username.clone(), }, Msg::DeleteUserResponse, "Error trying to delete user", ); } Msg::DismissModal => { self.modal.as_ref().expect("modal not initialized").hide(); } Msg::DeleteUserResponse(response) => { response?; ctx.props() .on_user_deleted .emit(ctx.props().username.clone()); } } Ok(true) } fn mut_common(&mut self) -> &mut CommonComponentParts { &mut self.common } } impl Component for DeleteUser { type Message = Msg; type Properties = DeleteUserProps; fn create(_: &Context) -> Self { Self { common: CommonComponentParts::::create(), node_ref: NodeRef::default(), modal: None, } } fn rendered(&mut self, _: &Context, first_render: bool) { if first_render { self.modal = Some(Modal::new( self.node_ref .cast::() .expect("Modal node is not an element"), )); } } fn update(&mut self, ctx: &Context, msg: Self::Message) -> bool { CommonComponentParts::::update_and_report_error( self, ctx, msg, ctx.props().on_error.clone(), ) } fn view(&self, ctx: &Context) -> Html { let link = &ctx.link(); html! { <> {self.show_modal(ctx)} } } } impl DeleteUser { fn show_modal(&self, ctx: &Context) -> Html { let link = &ctx.link(); html! { } } }