summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/codegen/mod.rs40
-rw-r--r--src/main.rs2
-rw-r--r--src/types/mod.rs34
-rw-r--r--src/types/props.rs44
-rw-r--r--src/types/rendered_element.rs36
5 files changed, 108 insertions, 48 deletions
diff --git a/src/codegen/mod.rs b/src/codegen/mod.rs
index 8e31dc3..5ce8425 100644
--- a/src/codegen/mod.rs
+++ b/src/codegen/mod.rs
@@ -1,38 +1,40 @@
-use crate::types::{ElementName, RenderedElement};
+use crate::types::{props::Props, rendered_element::RenderedElement, ElementName};
impl RenderedElement {
- pub fn codegen(&self) -> Result<(String, String), &str> {
+ pub fn codegen(&self) -> (String, String) {
let mut imports = String::new();
let mut view = String::new();
let mut props = String::new();
let mut elements = String::new();
- match self.children {
- Some(els) => {
- for el in els {
- let mut children = String::new();
+ for element in &self.child_elements {
+ let mut children = String::new();
- match el.codegen() {
- Ok(e) => (children, imports) = e,
- Err(err) => return Err(err),
- }
- elements = format!("{elements},{}", children);
- }
- }
- None => {}
+ (imports, children) = element.codegen();
+ elements = format!("{elements}{},", children);
}
- match self.name {
+ match &self.name {
+ ElementName::Container => {
+ imports = format!("{imports}\nuse iced::widget::container;");
+ view = if self.child_elements.len() < 2 {
+ format!("{view}\ncontainer({elements}){props}")
+ } else {
+ format!("{view}\ncontainer(){props}")
+ };
+ }
ElementName::Row => {
imports = format!("{imports}\nuse iced::widget::row;");
- view = format!("{view}\nrow![{elements}]{props};");
+ view = format!("{view}\nrow![{elements}]{props}");
}
- ElementName::Container => {
- imports = format!("{imports}\nuse iced::widget::container;");
- view = format!("{view}\ncontainer({elements}){props};");
+ ElementName::Text(string) => {
+ imports = format!("{imports}\nuse iced::widget::text;");
+ view = format!("{view}\ntext(\"{string}\"){props}");
}
_ => {}
}
+
+ (imports, view)
}
}
diff --git a/src/main.rs b/src/main.rs
index 16a1daa..b195c27 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -13,7 +13,7 @@ use iced::{
Alignment, Application, Color, Command, Element, Font, Length, Settings,
};
use rust_format::{Formatter, RustFmt};
-use types::{DesignerPage, DesignerState};
+use types::{rendered_element::RenderedElement, DesignerPage, DesignerState};
fn main() -> iced::Result {
App::run(Settings::default())
diff --git a/src/types/mod.rs b/src/types/mod.rs
index 09b0f07..60b28f7 100644
--- a/src/types/mod.rs
+++ b/src/types/mod.rs
@@ -1,24 +1,17 @@
-use std::path::PathBuf;
+pub mod props;
+pub mod rendered_element;
-use iced::{
- alignment::{Horizontal, Vertical},
- widget::{text::Shaping, text_editor},
- Alignment, ContentFit, Font, Length,
-};
+use iced::widget::text_editor;
+use rendered_element::RenderedElement;
+use std::path::PathBuf;
pub struct DesignerState {
pub designer_content: Vec<RenderedElement>,
pub designer_page: DesignerPage,
}
-pub struct RenderedElement {
- pub id: String,
- pub children: Option<Vec<RenderedElement>>,
- pub name: ElementName,
- pub props: Props,
-}
-
pub enum ElementName {
+ App(String, iced::Theme),
Text(String),
Button(String),
TextEditor(text_editor::Content),
@@ -29,21 +22,6 @@ pub enum ElementName {
Column,
}
-pub struct Props {
- pub align_items: Option<Alignment>,
- pub align_x: Option<Horizontal>,
- pub align_y: Option<Vertical>,
- pub horizontal_alignment: Option<Horizontal>,
- pub vertical_alignment: Option<Vertical>,
- pub height: Option<Length>,
- pub width: Option<Length>,
- pub font: Option<Font>,
- pub padding: Option<i32>,
- pub spacing: Option<i32>,
- pub content_fit: Option<ContentFit>,
- pub shaping: Option<Shaping>,
-}
-
pub enum DesignerPage {
Designer,
CodeView,
diff --git a/src/types/props.rs b/src/types/props.rs
new file mode 100644
index 0000000..6dbb0a4
--- /dev/null
+++ b/src/types/props.rs
@@ -0,0 +1,44 @@
+use core::f32;
+
+use iced::{
+ alignment::{Horizontal, Vertical},
+ widget::text::Shaping,
+ Alignment, ContentFit, Font, Length, Padding,
+};
+pub struct Props {
+ pub align_items: Option<Alignment>,
+ pub align_x: Option<Horizontal>,
+ pub align_y: Option<Vertical>,
+ pub horizontal_alignment: Option<Horizontal>,
+ pub vertical_alignment: Option<Vertical>,
+ pub width: Option<Length>,
+ pub height: Option<Length>,
+ pub max_width: Option<f32>,
+ pub max_height: Option<f32>,
+ pub font: Option<Font>,
+ pub padding: Option<Padding>,
+ pub spacing: Option<f32>,
+ pub content_fit: Option<ContentFit>,
+ pub shaping: Option<Shaping>,
+}
+
+impl Default for Props {
+ fn default() -> Self {
+ Self {
+ align_items: None,
+ align_x: None,
+ align_y: None,
+ horizontal_alignment: None,
+ vertical_alignment: None,
+ width: None,
+ height: None,
+ max_width: None,
+ max_height: None,
+ font: None,
+ padding: None,
+ spacing: None,
+ content_fit: None,
+ shaping: None,
+ }
+ }
+}
diff --git a/src/types/rendered_element.rs b/src/types/rendered_element.rs
new file mode 100644
index 0000000..e909ac5
--- /dev/null
+++ b/src/types/rendered_element.rs
@@ -0,0 +1,36 @@
+use unique_id::{string::StringGenerator, Generator};
+
+use super::{props::Props, ElementName};
+pub struct RenderedElement {
+ pub id: String,
+ pub child_elements: Vec<RenderedElement>,
+ pub name: ElementName,
+ pub props: Props,
+}
+
+impl RenderedElement {
+ pub fn new(name: ElementName) -> Self {
+ let gen = StringGenerator::default();
+ Self {
+ id: gen.next_id(),
+ child_elements: vec![],
+ name,
+ props: Props::default(),
+ }
+ }
+
+ pub fn from_vec(name: ElementName, child_elements: Vec<RenderedElement>) -> Self {
+ let gen = StringGenerator::default();
+ Self {
+ id: gen.next_id(),
+ child_elements,
+ name,
+ props: Props::default(),
+ }
+ }
+
+ pub fn push(mut self, element: RenderedElement) -> Self {
+ self.child_elements.push(element);
+ self
+ }
+}