This commit is contained in:
Franz Dietrich 2021-06-07 14:00:59 +02:00
parent 5da1d3fb16
commit f83a48ac3f
3 changed files with 27 additions and 11 deletions

View File

@ -26,4 +26,4 @@ enum-map = "1"
qrcode = "0.12"
image = "0.23"
shared = { path = "../shared" }
shared = { path = "../shared" }

View File

@ -38,6 +38,7 @@ pub fn init(mut url: Url, orders: &mut impl Orders<Msg>, i18n: I18n) -> Model {
formconfig: LinkRequestForm::default(), // when requesting links the form is stored here
inputs: EnumMap::default(), // the input fields for the searches
dialog,
handle: None,
}
}
@ -48,6 +49,7 @@ pub struct Model {
formconfig: LinkRequestForm, // when requesting links the form is stored here
inputs: EnumMap<LinkOverviewColumns, FilterInput>, // the input fields for the searches
dialog: Dialog, // User interaction - there can only ever be one dialog open.
handle: Option<CmdHandle>, // Rendering qr-codes takes time... it is aborted when this handle is dropped and replaced.
}
#[derive(Debug, Clone)]
@ -68,15 +70,14 @@ pub struct QrGuard {
}
impl QrGuard {
fn new(link_delta: LinkDelta) -> Self {
fn new(code: &str) -> Self {
use std::iter::FromIterator;
log!("Generating new QrCode");
let LinkDelta { code, .. } = link_delta;
let svg = generate_qr_from_code(&code);
let svg = generate_qr_from_code(code);
let mut properties = web_sys::BlobPropertyBag::new();
properties.type_("image/png");
let png_vec = generate_qr_png(&code);
let png_vec = generate_qr_png(code);
let png_jsarray: JsValue = js_sys::Uint8Array::from(&png_vec[..]).into();
// the buffer has to be an array of arrays
@ -89,6 +90,12 @@ impl QrGuard {
}
}
impl Drop for QrGuard {
fn drop(&mut self) {
let _ = web_sys::Url::revoke_object_url(&self.url);
}
}
#[derive(Default, Debug, Clone)]
struct FilterInput {
filter_input: ElRef<web_sys::HtmlInputElement>,
@ -270,10 +277,10 @@ pub fn process_edit_messages(msg: EditMsg, model: &mut Model, orders: &mut impl
qr: Loadable::Data(None),
};
log!("#loaded dialog");
orders.perform_cmd(async move {
let qr_code = Loadable::Data(Some(QrGuard::new(link_delta)));
model.handle = Some(orders.perform_cmd_with_handle(async move {
let qr_code = Loadable::Data(Some(QrGuard::new(&link_delta.code)));
Msg::Edit(EditMsg::QrGeneration(qr_code))
});
}));
orders.force_render_now();
log!("#after async");
}
@ -315,7 +322,11 @@ pub fn process_edit_messages(msg: EditMsg, model: &mut Model, orders: &mut impl
ref mut link_delta, ..
} = model.dialog
{
link_delta.code = s;
link_delta.code = s.clone();
model.handle = Some(orders.perform_cmd_with_handle(async move {
let qr_code = Loadable::Data(Some(QrGuard::new(&s)));
Msg::Edit(EditMsg::QrGeneration(qr_code))
}));
}
}
EditMsg::EditDescriptionChanged(s) => {
@ -667,7 +678,7 @@ fn edit_or_create_link<F: Fn(&str) -> String>(
attrs! {
At::Value => &link.code,
At::Type => "text",
At::Placeholder => t("password")
At::Placeholder => t("link-code")
},
input_ev(Ev::Input, |s| { Msg::Edit(EditMsg::EditCodeChanged(s)) }),
],]
@ -676,7 +687,7 @@ fn edit_or_create_link<F: Fn(&str) -> String>(
th![t("qr-code")],
if let Loadable::Data(Some(qr)) = qr {
td![a![
span!["Download", raw!(&qr.svg),],
span![C!["qrdownload"], "Download", raw!(&qr.svg),],
attrs!(At::Href => qr.url, At::Download => "qr-code.png")
]]
} else {

View File

@ -208,4 +208,9 @@ a {
img.trashicon {
width: 0.5cm;
}
qrdownload {
display: flex;
vertical-align: middle;
}