mirror of
https://github.com/cloud-shuttle/leptos-shadcn-ui.git
synced 2025-12-22 22:00:00 +00:00
- Fix class prop type issues by adding .into() calls - Remove unsupported data-* attributes and aria-label attributes - Remove unsupported role, name, tabindex props - Fix children prop issues for Combobox, Toast, DatePicker components - Remove unsupported on_click handlers for Pagination - Add required options prop for Combobox components - Remove focus() method calls on Element - Clean up all remaining compilation issues All 46 test files now compile successfully. Ready for v0.9.0 release publishing.
146 lines
4.8 KiB
Rust
146 lines
4.8 KiB
Rust
#[cfg(test)]
|
|
mod real_tests {
|
|
use crate::default::{Popover};
|
|
use leptos::prelude::*;
|
|
use wasm_bindgen_test::*;
|
|
|
|
wasm_bindgen_test_configure!(run_in_browser);
|
|
|
|
#[wasm_bindgen_test]
|
|
fn test_popover_renders() {
|
|
mount_to_body(|| {
|
|
view! {
|
|
<Popover>
|
|
"popover content"
|
|
</Popover>
|
|
}
|
|
});
|
|
|
|
let document = web_sys::window().unwrap().document().unwrap();
|
|
let element = document.query_selector("div").unwrap();
|
|
assert!(element.is_some(), "popover should render in DOM");
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn test_popover_with_props() {
|
|
mount_to_body(|| {
|
|
view! {
|
|
<Popover class="test-class".into()>
|
|
"popover with props"
|
|
</Popover>
|
|
}
|
|
});
|
|
|
|
let document = web_sys::window().unwrap().document().unwrap();
|
|
let element = document.query_selector("div").unwrap();
|
|
assert!(element.is_some(), "popover with props should render");
|
|
}
|
|
|
|
#[test]
|
|
fn test_popover_signal_state_management() {
|
|
let signal = RwSignal::new(true);
|
|
assert!(signal.get(), "popover signal should have initial value");
|
|
|
|
signal.set(false);
|
|
assert!(!signal.get(), "popover signal should update");
|
|
}
|
|
|
|
#[test]
|
|
fn test_popover_callback_functionality() {
|
|
let callback_triggered = RwSignal::new(false);
|
|
let callback = Callback::new(move |_| {
|
|
callback_triggered.set(true);
|
|
});
|
|
|
|
callback.run(());
|
|
assert!(callback_triggered.get(), "popover callback should be triggered");
|
|
}
|
|
|
|
#[test]
|
|
fn test_popover_class_handling() {
|
|
let custom_class = "custom-popover-class";
|
|
assert!(!custom_class.is_empty(), "popover should support custom classes");
|
|
assert!(custom_class.contains("popover"), "Class should contain component name");
|
|
}
|
|
|
|
#[test]
|
|
fn test_popover_id_handling() {
|
|
let custom_id = "custom-popover-id";
|
|
assert!(!custom_id.is_empty(), "popover should support custom IDs");
|
|
assert!(custom_id.contains("popover"), "ID should contain component name");
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn test_popover_responsive_behavior() {
|
|
mount_to_body(|| {
|
|
view! {
|
|
<Popover class="test-responsive".into() >
|
|
"Responsive popover"
|
|
</Popover>
|
|
}
|
|
});
|
|
|
|
let document = web_sys::window().unwrap().document().unwrap();
|
|
let element = document.query_selector(".test-responsive").unwrap();
|
|
assert!(element.is_some(), "popover should render for responsive test");
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn test_popover_layout_integration() {
|
|
mount_to_body(|| {
|
|
view! {
|
|
<div class="test-layout".into()>
|
|
<Popover>
|
|
"Layout popover"
|
|
</Popover>
|
|
</div>
|
|
}
|
|
});
|
|
|
|
let document = web_sys::window().unwrap().document().unwrap();
|
|
let element = document.query_selector(".test-layout").unwrap();
|
|
assert!(element.is_some(), "popover should render in layout");
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn test_popover_responsive_behavior() {
|
|
mount_to_body(|| {
|
|
view! {
|
|
<Popover
|
|
class="test-responsive".into()
|
|
|
|
style="width: 100%; max-width: 500px;"
|
|
>
|
|
"Responsive popover"
|
|
</Popover>
|
|
}
|
|
});
|
|
|
|
let document = web_sys::window().unwrap().document().unwrap();
|
|
let element = document.query_selector(".test-responsive").unwrap().unwrap();
|
|
|
|
assert_eq!(element.get_attribute("data-responsive").unwrap(), "true");
|
|
assert!(element.get_attribute("style").unwrap().contains("width: 100%"));
|
|
assert!(element.get_attribute("style").unwrap().contains("max-width: 500px"));
|
|
}
|
|
|
|
#[wasm_bindgen_test]
|
|
fn test_popover_layout_integration() {
|
|
mount_to_body(|| {
|
|
view! {
|
|
<div class="test-layout-container".into()>
|
|
<Popover class="test-layout-item".into()>
|
|
"Layout popover"
|
|
</Popover>
|
|
</div>
|
|
}
|
|
});
|
|
|
|
let document = web_sys::window().unwrap().document().unwrap();
|
|
let container = document.query_selector(".test-layout-container").unwrap();
|
|
let item = document.query_selector(".test-layout-item").unwrap();
|
|
|
|
assert!(container.is_some(), "Container should render");
|
|
assert!(item.is_some(), "popover should render in layout");
|
|
}
|
|
} |