miden-client-web 0.14.2

Web Client library that facilitates interaction with the Miden network
use miden_client::asset::TokenSymbol as NativeTokenSymbol;
use wasm_bindgen::prelude::*;

use crate::js_error_with_context;

/// Represents a string token symbol (e.g. "POL", "ETH") as a single {@link Felt | `Felt`} value.
///
/// Token Symbols can consists of up to 6 capital Latin characters, e.g. "C", "ETH", "MIDENC".
#[wasm_bindgen]
#[derive(Clone)]
pub struct TokenSymbol(NativeTokenSymbol);

#[wasm_bindgen]
impl TokenSymbol {
    /// Creates a token symbol from a string.
    #[wasm_bindgen(constructor)]
    pub fn new(symbol: &str) -> Result<TokenSymbol, JsValue> {
        let native_token_symbol = NativeTokenSymbol::new(symbol)
            .map_err(|err| js_error_with_context(err, "failed to create token symbol"))?;
        Ok(TokenSymbol(native_token_symbol))
    }

    /// Returns the validated symbol string.
    #[wasm_bindgen(js_name = "toString")]
    #[allow(clippy::inherent_to_string)]
    pub fn to_string(&self) -> String {
        self.0.to_string()
    }
}

// CONVERSIONS
// ================================================================================================

impl From<NativeTokenSymbol> for TokenSymbol {
    fn from(native_token_symbol: NativeTokenSymbol) -> Self {
        TokenSymbol(native_token_symbol)
    }
}

impl From<&NativeTokenSymbol> for TokenSymbol {
    fn from(native_token_symbol: &NativeTokenSymbol) -> Self {
        TokenSymbol(native_token_symbol.clone())
    }
}

impl From<TokenSymbol> for NativeTokenSymbol {
    fn from(token_symbol: TokenSymbol) -> Self {
        token_symbol.0
    }
}

impl From<&TokenSymbol> for NativeTokenSymbol {
    fn from(token_symbol: &TokenSymbol) -> Self {
        token_symbol.0.clone()
    }
}