[pdm-devel] [PATCH yew-comp v3 3/3] utils: split out clipboard helpers into their own modules
Shannon Sterz
s.sterz at proxmox.com
Fri Oct 17 14:51:00 CEST 2025
On Fri Oct 17, 2025 at 2:46 PM CEST, Shannon Sterz wrote:
> to make the utils module a little bit easier to navigate split out
> some functionality into their own submodules and re-export their
> functions. start with the clipboard helpers for now.
>
sorry forgot to add this initially:
Suggested-by: Lukas Wagner <l.wagner at proxmox.com>
> Signed-off-by: Shannon Sterz <s.sterz at proxmox.com>
> ---
> src/utils/clipboard.rs | 46 +++++++++++++++++++++++++++++++++
> src/{utils.rs => utils/mod.rs} | 47 +++-------------------------------
> 2 files changed, 50 insertions(+), 43 deletions(-)
> create mode 100644 src/utils/clipboard.rs
> rename src/{utils.rs => utils/mod.rs} (92%)
>
> diff --git a/src/utils/clipboard.rs b/src/utils/clipboard.rs
> new file mode 100644
> index 0000000..26dde05
> --- /dev/null
> +++ b/src/utils/clipboard.rs
> @@ -0,0 +1,46 @@
> +use wasm_bindgen::JsCast;
> +use yew::NodeRef;
> +
> +use pwt::convert_js_error;
> +
> +#[deprecated(
> + note = "This relies on the deprecated `execCommand` method. Please use `utils::copy_text_to_clipboard` instead."
> +)]
> +/// Copies the content of the passed `NodeRef` to the user's clipboard. The `NodeRef` should be
> +/// caste-able to `web_sys::HtmlInputElement`.
> +pub fn copy_to_clipboard(node_ref: &NodeRef) {
> + if let Some(el) = node_ref.cast::<web_sys::HtmlInputElement>() {
> + let window = gloo_utils::window();
> + let document = gloo_utils::document();
> +
> + let selection = window.get_selection().unwrap().unwrap();
> + let _ = selection.remove_all_ranges();
> +
> + let range = document.create_range().unwrap();
> + let _ = range.select_node_contents(&el);
> +
> + let _ = selection.add_range(&range);
> +
> + let document = document.dyn_into::<web_sys::HtmlDocument>().unwrap();
> + let _ = document.exec_command("copy");
> + }
> +}
> +
> +/// Copies `text` to a user's clipboard via the `Clipboard` API.
> +pub fn copy_text_to_clipboard(text: &str) {
> + let text = text.to_owned();
> +
> + wasm_bindgen_futures::spawn_local(async move {
> + let future: wasm_bindgen_futures::JsFuture = gloo_utils::window()
> + .navigator()
> + .clipboard()
> + .write_text(&text)
> + .into();
> +
> + let res = future.await.map_err(convert_js_error);
> +
> + if let Err(e) = res {
> + log::error!("could not copy to clipboard: {e:#}");
> + }
> + });
> +}
> diff --git a/src/utils.rs b/src/utils/mod.rs
> similarity index 92%
> rename from src/utils.rs
> rename to src/utils/mod.rs
> index e793414..c55431f 100644
> --- a/src/utils.rs
> +++ b/src/utils/mod.rs
> @@ -2,16 +2,17 @@ use std::collections::HashMap;
> use std::fmt::Display;
> use std::sync::Mutex;
>
> -use pwt::convert_js_error;
> use serde_json::Value;
> -use wasm_bindgen::JsCast;
> use yew::prelude::*;
> -use yew::NodeRef;
>
> use crate::common_api_types::ProxmoxUpid;
>
> use pwt::tr;
>
> +mod clipboard;
> +#[allow(deprecated)]
> +pub use clipboard::{copy_text_to_clipboard, copy_to_clipboard};
> +
> /// Somewhat like a human would tell durations, omit zero values and do not
> /// give seconds precision if we talk days already
> pub fn format_duration_human(ut: f64) -> String {
> @@ -339,46 +340,6 @@ pub fn json_array_to_flat_string(list: &[Value]) -> String {
> list.join(" ")
> }
>
> -#[deprecated(
> - note = "This relies on the deprecated `execCommand` method. Please use `utils::copy_text_to_clipboard` instead."
> -)]
> -pub fn copy_to_clipboard(node_ref: &NodeRef) {
> - if let Some(el) = node_ref.cast::<web_sys::HtmlInputElement>() {
> - let window = gloo_utils::window();
> - let document = gloo_utils::document();
> -
> - let selection = window.get_selection().unwrap().unwrap();
> - let _ = selection.remove_all_ranges();
> -
> - let range = document.create_range().unwrap();
> - let _ = range.select_node_contents(&el);
> -
> - let _ = selection.add_range(&range);
> -
> - let document = document.dyn_into::<web_sys::HtmlDocument>().unwrap();
> - let _ = document.exec_command("copy");
> - }
> -}
> -
> -/// Copies `text` to a user's clipboard via the `Clipboard` API.
> -pub fn copy_text_to_clipboard(text: &str) {
> - let text = text.to_owned();
> -
> - wasm_bindgen_futures::spawn_local(async move {
> - let future: wasm_bindgen_futures::JsFuture = gloo_utils::window()
> - .navigator()
> - .clipboard()
> - .write_text(&text)
> - .into();
> -
> - let res = future.await.map_err(convert_js_error);
> -
> - if let Err(e) = res {
> - log::error!("could not copy to clipboard: {e:#}");
> - }
> - });
> -}
> -
> /// Set the browser window.location.href
> pub fn set_location_href(href: &str) {
> let window = gloo_utils::window();
> --
> 2.47.3
More information about the pdm-devel
mailing list