use cgmath::Point2;
use std::{
cell::RefCell,
default::default,
fmt::{Debug, Formatter, Result},
rc::Rc,
};
use stretch::{node::Node, style};
use crate::prelude::Singleton;
use crate::{
foundation::Signal,
rendering::backend::{WidgetRenderFactory, WidgetRenderHolder},
services::LayoutSystem,
widgets::Placeholder,
};
use super::{Element, WidgetComponent};
#[derive(Default, Debug, Clone)]
struct PlaceholderState {
path: String,
}
pub struct PlaceholderElement {
component: Rc<RefCell<WidgetComponent>>,
state: RefCell<PlaceholderState>,
pub onchange: Signal<String>,
pub renderer: Option<Rc<WidgetRenderHolder<Self>>>,
pub node: Node,
}
impl Debug for PlaceholderElement {
fn fmt(&self, f: &mut Formatter<'_>) -> Result {
f.debug_struct("PlaceholderElement").finish()
}
}
impl PlaceholderElement {
pub fn new(widget: &Placeholder) -> Self {
let node = LayoutSystem::new_node(style::Style { ..default() }, vec![]).unwrap();
let component = WidgetComponent::get(widget.key.id());
let path = String::new();
Self {
component,
state: RefCell::new(PlaceholderState { path }),
onchange: Signal::new(),
renderer: WidgetRenderFactory::global().get::<Self>(),
node,
}
}
pub fn path(&self) -> String {
self.state.borrow().path.clone()
}
pub fn set_path(&self, path: String) {
self.state.borrow_mut().path = path.clone();
self.onchange.emit(&path);
}
}
impl AsRef<RefCell<WidgetComponent>> for PlaceholderElement {
fn as_ref(&self) -> &RefCell<WidgetComponent> {
self.component.as_ref()
}
}
impl Element for PlaceholderElement {
fn destroy(&self) {
self.onchange.clear();
}
fn node(&self) -> Option<Node> {
Some(self.node)
}
fn relayout(&self, origin: Point2<f32>) {
let update_childs = match LayoutSystem::layout(self.node) {
Ok(layout) => {
let mut comp = self.as_ref().borrow_mut();
comp.x = layout.location.x + origin.x;
comp.y = layout.location.y + origin.y;
comp.w = layout.size.width;
comp.h = layout.size.height;
true
}
Err(e) => {
log::error!("{}", e);
false
}
};
if update_childs {
}
}
}