mirror of
https://github.com/nitnelave/lldap.git
synced 2023-04-12 14:25:13 +00:00
app: Migrate DeleteUser to CommonComponent
This commit is contained in:
parent
5523d38838
commit
d4ac9fa703
@ -1,9 +1,10 @@
|
|||||||
use crate::infra::{api::HostService, modal::Modal};
|
use crate::infra::{
|
||||||
|
common_component::{CommonComponent, CommonComponentParts},
|
||||||
|
modal::Modal,
|
||||||
|
};
|
||||||
use anyhow::{Error, Result};
|
use anyhow::{Error, Result};
|
||||||
use graphql_client::GraphQLQuery;
|
use graphql_client::GraphQLQuery;
|
||||||
use yew::prelude::*;
|
use yew::prelude::*;
|
||||||
use yew::services::fetch::FetchTask;
|
|
||||||
use yewtil::NeqAssign;
|
|
||||||
|
|
||||||
#[derive(GraphQLQuery)]
|
#[derive(GraphQLQuery)]
|
||||||
#[graphql(
|
#[graphql(
|
||||||
@ -15,11 +16,9 @@ use yewtil::NeqAssign;
|
|||||||
pub struct DeleteUserQuery;
|
pub struct DeleteUserQuery;
|
||||||
|
|
||||||
pub struct DeleteUser {
|
pub struct DeleteUser {
|
||||||
link: ComponentLink<Self>,
|
common: CommonComponentParts<Self>,
|
||||||
props: DeleteUserProps,
|
|
||||||
node_ref: NodeRef,
|
node_ref: NodeRef,
|
||||||
modal: Option<Modal>,
|
modal: Option<Modal>,
|
||||||
task: Option<FetchTask>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(yew::Properties, Clone, PartialEq, Debug)]
|
#[derive(yew::Properties, Clone, PartialEq, Debug)]
|
||||||
@ -36,17 +35,51 @@ pub enum Msg {
|
|||||||
DeleteUserResponse(Result<delete_user_query::ResponseData>),
|
DeleteUserResponse(Result<delete_user_query::ResponseData>),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl CommonComponent<DeleteUser> for DeleteUser {
|
||||||
|
fn handle_msg(&mut self, msg: <Self as Component>::Message) -> Result<bool> {
|
||||||
|
match msg {
|
||||||
|
Msg::ClickedDeleteUser => {
|
||||||
|
self.modal.as_ref().expect("modal not initialized").show();
|
||||||
|
}
|
||||||
|
Msg::ConfirmDeleteUser => {
|
||||||
|
self.update(Msg::DismissModal);
|
||||||
|
self.common.call_graphql::<DeleteUserQuery, _>(
|
||||||
|
delete_user_query::Variables {
|
||||||
|
user: self.common.props.username.clone(),
|
||||||
|
},
|
||||||
|
Msg::DeleteUserResponse,
|
||||||
|
"Error trying to delete user",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
Msg::DismissModal => {
|
||||||
|
self.modal.as_ref().expect("modal not initialized").hide();
|
||||||
|
}
|
||||||
|
Msg::DeleteUserResponse(response) => {
|
||||||
|
self.common.cancel_task();
|
||||||
|
response?;
|
||||||
|
self.common
|
||||||
|
.props
|
||||||
|
.on_user_deleted
|
||||||
|
.emit(self.common.props.username.clone());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Ok(true)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn mut_common(&mut self) -> &mut CommonComponentParts<Self> {
|
||||||
|
&mut self.common
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Component for DeleteUser {
|
impl Component for DeleteUser {
|
||||||
type Message = Msg;
|
type Message = Msg;
|
||||||
type Properties = DeleteUserProps;
|
type Properties = DeleteUserProps;
|
||||||
|
|
||||||
fn create(props: Self::Properties, link: ComponentLink<Self>) -> Self {
|
fn create(props: Self::Properties, link: ComponentLink<Self>) -> Self {
|
||||||
Self {
|
Self {
|
||||||
link,
|
common: CommonComponentParts::<Self>::create(props, link),
|
||||||
props,
|
|
||||||
node_ref: NodeRef::default(),
|
node_ref: NodeRef::default(),
|
||||||
modal: None,
|
modal: None,
|
||||||
task: None,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,39 +94,15 @@ impl Component for DeleteUser {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn update(&mut self, msg: Self::Message) -> ShouldRender {
|
fn update(&mut self, msg: Self::Message) -> ShouldRender {
|
||||||
match msg {
|
CommonComponentParts::<Self>::update_and_report_error(
|
||||||
Msg::ClickedDeleteUser => {
|
self,
|
||||||
self.modal.as_ref().expect("modal not initialized").show();
|
msg,
|
||||||
}
|
self.common.props.on_error.clone(),
|
||||||
Msg::ConfirmDeleteUser => {
|
|
||||||
self.update(Msg::DismissModal);
|
|
||||||
self.task = HostService::graphql_query::<DeleteUserQuery>(
|
|
||||||
delete_user_query::Variables {
|
|
||||||
user: self.props.username.clone(),
|
|
||||||
},
|
|
||||||
self.link.callback(Msg::DeleteUserResponse),
|
|
||||||
"Error trying to delete user",
|
|
||||||
)
|
)
|
||||||
.map_err(|e| self.props.on_error.emit(e))
|
|
||||||
.ok();
|
|
||||||
}
|
|
||||||
Msg::DismissModal => {
|
|
||||||
self.modal.as_ref().expect("modal not initialized").hide();
|
|
||||||
}
|
|
||||||
Msg::DeleteUserResponse(response) => {
|
|
||||||
self.task = None;
|
|
||||||
if let Err(e) = response {
|
|
||||||
self.props.on_error.emit(e);
|
|
||||||
} else {
|
|
||||||
self.props.on_user_deleted.emit(self.props.username.clone());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
true
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn change(&mut self, props: Self::Properties) -> ShouldRender {
|
fn change(&mut self, props: Self::Properties) -> ShouldRender {
|
||||||
self.props.neq_assign(props)
|
self.common.change(props)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn view(&self) -> Html {
|
fn view(&self) -> Html {
|
||||||
@ -101,8 +110,8 @@ impl Component for DeleteUser {
|
|||||||
<>
|
<>
|
||||||
<button
|
<button
|
||||||
class="btn btn-danger"
|
class="btn btn-danger"
|
||||||
disabled=self.task.is_some()
|
disabled=self.common.is_task_running()
|
||||||
onclick=self.link.callback(|_| Msg::ClickedDeleteUser)>
|
onclick=self.common.callback(|_| Msg::ClickedDeleteUser)>
|
||||||
<i class="bi-x-circle-fill" aria-label="Delete user" />
|
<i class="bi-x-circle-fill" aria-label="Delete user" />
|
||||||
</button>
|
</button>
|
||||||
{self.show_modal()}
|
{self.show_modal()}
|
||||||
@ -116,7 +125,7 @@ impl DeleteUser {
|
|||||||
html! {
|
html! {
|
||||||
<div
|
<div
|
||||||
class="modal fade"
|
class="modal fade"
|
||||||
id="deleteUserModal".to_string() + &self.props.username
|
id="deleteUserModal".to_string() + &self.common.props.username
|
||||||
tabindex="-1"
|
tabindex="-1"
|
||||||
//role="dialog"
|
//role="dialog"
|
||||||
aria-labelledby="deleteUserModalLabel"
|
aria-labelledby="deleteUserModalLabel"
|
||||||
@ -130,24 +139,24 @@ impl DeleteUser {
|
|||||||
type="button"
|
type="button"
|
||||||
class="btn-close"
|
class="btn-close"
|
||||||
aria-label="Close"
|
aria-label="Close"
|
||||||
onclick=self.link.callback(|_| Msg::DismissModal) />
|
onclick=self.common.callback(|_| Msg::DismissModal) />
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-body">
|
<div class="modal-body">
|
||||||
<span>
|
<span>
|
||||||
{"Are you sure you want to delete user "}
|
{"Are you sure you want to delete user "}
|
||||||
<b>{&self.props.username}</b>{"?"}
|
<b>{&self.common.props.username}</b>{"?"}
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-footer">
|
<div class="modal-footer">
|
||||||
<button
|
<button
|
||||||
type="button"
|
type="button"
|
||||||
class="btn btn-secondary"
|
class="btn btn-secondary"
|
||||||
onclick=self.link.callback(|_| Msg::DismissModal)>
|
onclick=self.common.callback(|_| Msg::DismissModal)>
|
||||||
{"Cancel"}
|
{"Cancel"}
|
||||||
</button>
|
</button>
|
||||||
<button
|
<button
|
||||||
type="button"
|
type="button"
|
||||||
onclick=self.link.callback(|_| Msg::ConfirmDeleteUser)
|
onclick=self.common.callback(|_| Msg::ConfirmDeleteUser)
|
||||||
class="btn btn-danger">{"Yes, I'm sure"}</button>
|
class="btn btn-danger">{"Yes, I'm sure"}</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
Reference in New Issue
Block a user