From 2be216043e47fd30e7342ef60d3cbb2f2a359c01 Mon Sep 17 00:00:00 2001 From: luoxiaozero <48741584+luoxiaozero@users.noreply.github.com> Date: Tue, 19 Mar 2024 23:04:16 +0800 Subject: [PATCH] Feat/thaw components (#146) * feat: extract utils as the library * fix: thaw_components dependencies --- Cargo.toml | 3 ++- thaw/Cargo.toml | 7 +++--- thaw/src/alert/mod.rs | 3 ++- thaw/src/auto_complete/mod.rs | 6 ++--- thaw/src/avatar/mod.rs | 3 ++- thaw/src/button/mod.rs | 7 ++---- thaw/src/card/mod.rs | 3 ++- thaw/src/checkbox/mod.rs | 3 ++- thaw/src/collapse/collapse_item.rs | 3 ++- thaw/src/color_picker/mod.rs | 6 ++--- thaw/src/components/mod.rs | 19 --------------- thaw/src/date_picker/mod.rs | 6 ++--- thaw/src/date_picker/panel/mod.rs | 3 ++- thaw/src/drawer/mod.rs | 6 ++--- thaw/src/lib.rs | 1 - thaw/src/loading_bar/loading_bar_provider.rs | 2 +- thaw/src/message/message_provider.rs | 2 +- thaw/src/message/mod.rs | 7 ++---- thaw/src/mobile/nav_bar/mod.rs | 3 ++- thaw/src/mobile/tabbar/tabbar_item.rs | 2 +- thaw/src/modal/mod.rs | 6 ++--- thaw/src/popover/mod.rs | 6 ++--- thaw/src/select/mod.rs | 7 ++---- thaw/src/slider/mod.rs | 3 ++- thaw/src/time_picker/mod.rs | 2 +- thaw_components/Cargo.toml | 23 +++++++++++++++++++ .../src}/binder/binder.css | 0 .../src}/binder/get_placement_style.rs | 0 .../src}/binder/mod.rs | 2 +- .../src}/css_transition/mod.rs | 0 .../src}/if_comp.rs | 0 thaw_components/src/lib.rs | 20 ++++++++++++++++ .../src}/option_comp.rs | 0 .../src}/teleport/mod.rs | 0 .../src}/wave/mod.rs | 0 .../src}/wave/wave.css | 0 thaw_utils/src/lib.rs | 2 +- 37 files changed, 89 insertions(+), 77 deletions(-) delete mode 100644 thaw/src/components/mod.rs create mode 100644 thaw_components/Cargo.toml rename {thaw/src/components => thaw_components/src}/binder/binder.css (100%) rename {thaw/src/components => thaw_components/src}/binder/get_placement_style.rs (100%) rename {thaw/src/components => thaw_components/src}/binder/mod.rs (99%) rename {thaw/src/components => thaw_components/src}/css_transition/mod.rs (100%) rename {thaw/src/components => thaw_components/src}/if_comp.rs (100%) create mode 100644 thaw_components/src/lib.rs rename {thaw/src/components => thaw_components/src}/option_comp.rs (100%) rename {thaw/src/components => thaw_components/src}/teleport/mod.rs (100%) rename {thaw/src/components => thaw_components/src}/wave/mod.rs (100%) rename {thaw/src/components => thaw_components/src}/wave/wave.css (100%) diff --git a/Cargo.toml b/Cargo.toml index ede66e1..1f169a8 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,8 +1,9 @@ [workspace] resolver = "2" -members = ["thaw", "thaw_utils", "demo", "demo_markdown"] +members = ["thaw", "thaw_components", "thaw_utils", "demo", "demo_markdown"] exclude = ["examples"] [workspace.dependencies] thaw = { version = "0.2.3", path = "./thaw" } +thaw_components = { version = "0.0.1", path = "./thaw_components" } thaw_utils = { version = "0.0.1", path = "./thaw_utils" } diff --git a/thaw/Cargo.toml b/thaw/Cargo.toml index 0f8812a..a391b9b 100644 --- a/thaw/Cargo.toml +++ b/thaw/Cargo.toml @@ -14,6 +14,7 @@ license = "MIT" [dependencies] leptos = { version = "0.6.9" } +thaw_components = { workspace = true } thaw_utils = { workspace = true } web-sys = { version = "0.3.69", features = [ "DomRect", @@ -30,6 +31,6 @@ chrono = "0.4.35" palette = "0.7.5" [features] -csr = ["leptos/csr", "thaw_utils/csr"] -ssr = ["leptos/ssr", "thaw_utils/ssr"] -hydrate = ["leptos/hydrate", "thaw_utils/hydrate"] +csr = ["leptos/csr", "thaw_components/csr", "thaw_utils/csr"] +ssr = ["leptos/ssr", "thaw_components/ssr", "thaw_utils/ssr"] +hydrate = ["leptos/hydrate", "thaw_components/hydrate", "thaw_utils/hydrate"] diff --git a/thaw/src/alert/mod.rs b/thaw/src/alert/mod.rs index 75cbb98..27880c1 100644 --- a/thaw/src/alert/mod.rs +++ b/thaw/src/alert/mod.rs @@ -2,8 +2,9 @@ mod theme; pub use theme::AlertTheme; -use crate::{components::OptionComp, theme::use_theme, Icon, Theme}; +use crate::{theme::use_theme, Icon, Theme}; use leptos::*; +use thaw_components::OptionComp; use thaw_utils::{class_list, mount_style, OptionalProp}; #[derive(Clone)] diff --git a/thaw/src/auto_complete/mod.rs b/thaw/src/auto_complete/mod.rs index c613aa6..cb8ea8b 100644 --- a/thaw/src/auto_complete/mod.rs +++ b/thaw/src/auto_complete/mod.rs @@ -2,11 +2,9 @@ mod theme; pub use theme::AutoCompleteTheme; -use crate::{ - components::{Binder, CSSTransition, Follower, FollowerPlacement, FollowerWidth}, - use_theme, ComponentRef, Input, InputPrefix, InputRef, InputSuffix, Theme, -}; +use crate::{use_theme, ComponentRef, Input, InputPrefix, InputRef, InputSuffix, Theme}; use leptos::*; +use thaw_components::{Binder, CSSTransition, Follower, FollowerPlacement, FollowerWidth}; use thaw_utils::{class_list, mount_style, Model, OptionalProp, StoredMaybeSignal}; #[derive(Clone, PartialEq)] diff --git a/thaw/src/avatar/mod.rs b/thaw/src/avatar/mod.rs index 5d31c4c..1ea5270 100644 --- a/thaw/src/avatar/mod.rs +++ b/thaw/src/avatar/mod.rs @@ -2,8 +2,9 @@ mod theme; pub use theme::AvatarTheme; -use crate::{components::OptionComp, use_theme, Theme}; +use crate::{use_theme, Theme}; use leptos::*; +use thaw_components::OptionComp; use thaw_utils::{class_list, mount_style, OptionalProp}; #[component] diff --git a/thaw/src/button/mod.rs b/thaw/src/button/mod.rs index 775e71d..ff4cbb5 100644 --- a/thaw/src/button/mod.rs +++ b/thaw/src/button/mod.rs @@ -4,12 +4,9 @@ mod theme; pub use button_group::ButtonGroup; pub use theme::ButtonTheme; -use crate::{ - components::{OptionComp, Wave, WaveRef}, - icon::Icon, - theme::*, -}; +use crate::{icon::Icon, theme::*}; use leptos::*; +use thaw_components::{OptionComp, Wave, WaveRef}; use thaw_utils::{class_list, mount_style, ComponentRef, OptionalMaybeSignal, OptionalProp}; #[derive(Default, PartialEq, Clone, Copy)] diff --git a/thaw/src/card/mod.rs b/thaw/src/card/mod.rs index 93d0380..437b0e1 100644 --- a/thaw/src/card/mod.rs +++ b/thaw/src/card/mod.rs @@ -1,5 +1,6 @@ -use crate::{components::*, use_theme, Theme}; +use crate::{use_theme, Theme}; use leptos::*; +use thaw_components::*; use thaw_utils::{class_list, mount_style, OptionalProp}; #[slot] diff --git a/thaw/src/checkbox/mod.rs b/thaw/src/checkbox/mod.rs index ada076c..41058b8 100644 --- a/thaw/src/checkbox/mod.rs +++ b/thaw/src/checkbox/mod.rs @@ -4,8 +4,9 @@ mod checkbox_item; pub use checkbox_group::CheckboxGroup; pub use checkbox_item::CheckboxItem; -use crate::{components::*, icon::*, theme::use_theme, Theme}; +use crate::{icon::*, theme::use_theme, Theme}; use leptos::*; +use thaw_components::*; use thaw_utils::{class_list, mount_style, Model, OptionalProp}; #[component] diff --git a/thaw/src/collapse/collapse_item.rs b/thaw/src/collapse/collapse_item.rs index aaa8894..18f8ca8 100644 --- a/thaw/src/collapse/collapse_item.rs +++ b/thaw/src/collapse/collapse_item.rs @@ -1,6 +1,7 @@ use super::use_collapse; -use crate::{components::CSSTransition, Icon}; +use crate::Icon; use leptos::*; +use thaw_components::CSSTransition; use thaw_utils::{class_list, OptionalProp, StoredMaybeSignal}; #[component] diff --git a/thaw/src/color_picker/mod.rs b/thaw/src/color_picker/mod.rs index 2bae56f..269c0f6 100644 --- a/thaw/src/color_picker/mod.rs +++ b/thaw/src/color_picker/mod.rs @@ -4,13 +4,11 @@ mod theme; pub use color::*; pub use theme::ColorPickerTheme; -use crate::{ - components::{Binder, CSSTransition, Follower, FollowerPlacement}, - use_theme, Theme, -}; +use crate::{use_theme, Theme}; use leptos::leptos_dom::helpers::WindowListenerHandle; use leptos::*; use palette::{Hsv, IntoColor, Srgb}; +use thaw_components::{Binder, CSSTransition, Follower, FollowerPlacement}; use thaw_utils::{class_list, mount_style, Model, OptionalProp}; #[component] diff --git a/thaw/src/components/mod.rs b/thaw/src/components/mod.rs deleted file mode 100644 index 8bbd702..0000000 --- a/thaw/src/components/mod.rs +++ /dev/null @@ -1,19 +0,0 @@ -mod binder; -mod css_transition; -mod if_comp; -mod option_comp; -mod teleport; -mod wave; - -pub(crate) use binder::*; -pub(crate) use css_transition::CSSTransition; -pub(crate) use if_comp::*; -use leptos::*; -pub(crate) use option_comp::*; -pub(crate) use teleport::*; -pub(crate) use wave::*; - -#[slot] -pub struct Fallback { - children: ChildrenFn, -} diff --git a/thaw/src/date_picker/mod.rs b/thaw/src/date_picker/mod.rs index 2ad3ac5..6797885 100644 --- a/thaw/src/date_picker/mod.rs +++ b/thaw/src/date_picker/mod.rs @@ -3,13 +3,11 @@ mod theme; pub use theme::DatePickerTheme; -use crate::{ - components::{Binder, Follower, FollowerPlacement}, - Icon, Input, InputSuffix, SignalWatch, -}; +use crate::{Icon, Input, InputSuffix, SignalWatch}; use chrono::NaiveDate; use leptos::*; use panel::{Panel, PanelRef}; +use thaw_components::{Binder, Follower, FollowerPlacement}; use thaw_utils::{mount_style, now_date, ComponentRef, Model, OptionalProp}; #[component] diff --git a/thaw/src/date_picker/panel/mod.rs b/thaw/src/date_picker/panel/mod.rs index 1e67d1d..9442d7a 100644 --- a/thaw/src/date_picker/panel/mod.rs +++ b/thaw/src/date_picker/panel/mod.rs @@ -2,11 +2,12 @@ mod date_panel; mod month_panel; mod year_panel; -use crate::{components::CSSTransition, use_theme, Theme}; +use crate::{use_theme, Theme}; use chrono::NaiveDate; use date_panel::DatePanel; use leptos::*; use month_panel::MonthPanel; +use thaw_components::CSSTransition; use thaw_utils::{now_date, ComponentRef}; use year_panel::YearPanel; diff --git a/thaw/src/drawer/mod.rs b/thaw/src/drawer/mod.rs index 5168953..dcc4c7f 100644 --- a/thaw/src/drawer/mod.rs +++ b/thaw/src/drawer/mod.rs @@ -1,8 +1,6 @@ -use crate::{ - components::{CSSTransition, Teleport}, - Card, -}; +use crate::Card; use leptos::*; +use thaw_components::{CSSTransition, Teleport}; use thaw_utils::{class_list, mount_style, use_lock_html_scroll, Model, OptionalProp}; #[component] diff --git a/thaw/src/lib.rs b/thaw/src/lib.rs index e166078..5f44cca 100644 --- a/thaw/src/lib.rs +++ b/thaw/src/lib.rs @@ -10,7 +10,6 @@ mod checkbox; mod code; mod collapse; mod color_picker; -mod components; mod date_picker; mod divider; mod drawer; diff --git a/thaw/src/loading_bar/loading_bar_provider.rs b/thaw/src/loading_bar/loading_bar_provider.rs index e7d8bce..ea79a76 100644 --- a/thaw/src/loading_bar/loading_bar_provider.rs +++ b/thaw/src/loading_bar/loading_bar_provider.rs @@ -1,6 +1,6 @@ use super::{LoadingBar, LoadingBarRef}; -use crate::components::Teleport; use leptos::*; +use thaw_components::Teleport; use thaw_utils::ComponentRef; #[component] diff --git a/thaw/src/message/message_provider.rs b/thaw/src/message/message_provider.rs index fde2f8f..f4865d6 100644 --- a/thaw/src/message/message_provider.rs +++ b/thaw/src/message/message_provider.rs @@ -1,7 +1,7 @@ use super::{message_environment::MessageEnvironment, MessageVariant}; -use crate::components::Teleport; use leptos::*; use std::time::Duration; +use thaw_components::Teleport; use thaw_utils::{class_list, mount_style}; use uuid::Uuid; diff --git a/thaw/src/message/mod.rs b/thaw/src/message/mod.rs index 8c45749..39b71be 100644 --- a/thaw/src/message/mod.rs +++ b/thaw/src/message/mod.rs @@ -5,12 +5,9 @@ mod theme; pub use message_provider::*; pub use theme::MessageTheme; -use crate::{ - components::{If, Then}, - theme::use_theme, - Icon, Theme, -}; +use crate::{theme::use_theme, Icon, Theme}; use leptos::*; +use thaw_components::{If, Then}; use uuid::Uuid; #[derive(Default, Clone)] diff --git a/thaw/src/mobile/nav_bar/mod.rs b/thaw/src/mobile/nav_bar/mod.rs index d7e81cf..b0eac3f 100644 --- a/thaw/src/mobile/nav_bar/mod.rs +++ b/thaw/src/mobile/nav_bar/mod.rs @@ -2,8 +2,9 @@ mod theme; pub use theme::NavBarTheme; -use crate::{components::*, icon::*, use_theme, Theme}; +use crate::{icon::*, use_theme, Theme}; use leptos::*; +use thaw_components::*; use thaw_utils::{class_list, mount_style, OptionalProp}; #[slot] diff --git a/thaw/src/mobile/tabbar/tabbar_item.rs b/thaw/src/mobile/tabbar/tabbar_item.rs index 362f196..290d21a 100644 --- a/thaw/src/mobile/tabbar/tabbar_item.rs +++ b/thaw/src/mobile/tabbar/tabbar_item.rs @@ -1,7 +1,7 @@ use super::use_tabbar; -use crate::components::*; use crate::{icon::Icon, theme::use_theme, Theme}; use leptos::*; +use thaw_components::*; use thaw_utils::{mount_style, StoredMaybeSignal}; #[component] diff --git a/thaw/src/modal/mod.rs b/thaw/src/modal/mod.rs index fa60fea..21e955d 100644 --- a/thaw/src/modal/mod.rs +++ b/thaw/src/modal/mod.rs @@ -1,8 +1,6 @@ -use crate::{ - components::{CSSTransition, OptionComp, Teleport}, - Card, CardFooter, CardHeader, CardHeaderExtra, Icon, -}; +use crate::{Card, CardFooter, CardHeader, CardHeaderExtra, Icon}; use leptos::*; +use thaw_components::{CSSTransition, OptionComp, Teleport}; use thaw_utils::{mount_style, use_click_position, Model}; #[slot] diff --git a/thaw/src/popover/mod.rs b/thaw/src/popover/mod.rs index 5e19b09..5053b16 100644 --- a/thaw/src/popover/mod.rs +++ b/thaw/src/popover/mod.rs @@ -2,12 +2,10 @@ mod theme; pub use theme::PopoverTheme; -use crate::{ - components::{Binder, CSSTransition, Follower, FollowerPlacement}, - use_theme, Theme, -}; +use crate::{use_theme, Theme}; use leptos::{leptos_dom::helpers::TimeoutHandle, *}; use std::time::Duration; +use thaw_components::{Binder, CSSTransition, Follower, FollowerPlacement}; use thaw_utils::{add_event_listener, class_list, mount_style, OptionalProp}; #[slot] diff --git a/thaw/src/select/mod.rs b/thaw/src/select/mod.rs index fadd6e7..efacb81 100644 --- a/thaw/src/select/mod.rs +++ b/thaw/src/select/mod.rs @@ -2,13 +2,10 @@ mod theme; pub use theme::SelectTheme; -use crate::{ - components::{Binder, CSSTransition, Follower, FollowerPlacement, FollowerWidth}, - theme::use_theme, - Theme, -}; +use crate::{theme::use_theme, Theme}; use leptos::*; use std::hash::Hash; +use thaw_components::{Binder, CSSTransition, Follower, FollowerPlacement, FollowerWidth}; use thaw_utils::{class_list, mount_style, Model, OptionalProp}; #[derive(Clone, PartialEq, Eq, Hash)] diff --git a/thaw/src/slider/mod.rs b/thaw/src/slider/mod.rs index 3dc8563..0776298 100644 --- a/thaw/src/slider/mod.rs +++ b/thaw/src/slider/mod.rs @@ -4,8 +4,9 @@ mod theme; pub use slider_label::SliderLabel; pub use theme::SliderTheme; -use crate::{components::OptionComp, theme::use_theme, Theme}; +use crate::{theme::use_theme, Theme}; use leptos::*; +use thaw_components::OptionComp; use thaw_utils::{class_list, mount_style, Model, OptionalProp}; use web_sys::DomRect; diff --git a/thaw/src/time_picker/mod.rs b/thaw/src/time_picker/mod.rs index 0da5a97..56e6c38 100644 --- a/thaw/src/time_picker/mod.rs +++ b/thaw/src/time_picker/mod.rs @@ -3,11 +3,11 @@ mod theme; pub use theme::TimePickerTheme; use crate::{ - components::{Binder, CSSTransition, Follower, FollowerPlacement}, use_theme, Button, ButtonSize, ButtonVariant, Icon, Input, InputSuffix, SignalWatch, Theme, }; use chrono::{Local, NaiveTime, Timelike}; use leptos::*; +use thaw_components::{Binder, CSSTransition, Follower, FollowerPlacement}; use thaw_utils::{mount_style, ComponentRef, Model, OptionalProp}; #[component] diff --git a/thaw_components/Cargo.toml b/thaw_components/Cargo.toml new file mode 100644 index 0000000..b1f705c --- /dev/null +++ b/thaw_components/Cargo.toml @@ -0,0 +1,23 @@ +[package] +name = "thaw_components" +version = "0.0.1" +edition = "2021" +keywords = ["leptos", "thaw", "components"] +readme = "../README.md" +authors = ["luoxiaozero"] +description = "Shared Thaw internal components" +repository = "https://github.com/thaw-ui/thaw" +license = "MIT" + +# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html + +[dependencies] +leptos = { version = "0.6.9" } +thaw_utils = { workspace = true } +web-sys = { version = "0.3.69", features = ["DomRect"] } +cfg-if = "1.0.0" + +[features] +csr = ["leptos/csr"] +ssr = ["leptos/ssr"] +hydrate = ["leptos/hydrate"] diff --git a/thaw/src/components/binder/binder.css b/thaw_components/src/binder/binder.css similarity index 100% rename from thaw/src/components/binder/binder.css rename to thaw_components/src/binder/binder.css diff --git a/thaw/src/components/binder/get_placement_style.rs b/thaw_components/src/binder/get_placement_style.rs similarity index 100% rename from thaw/src/components/binder/get_placement_style.rs rename to thaw_components/src/binder/get_placement_style.rs diff --git a/thaw/src/components/binder/mod.rs b/thaw_components/src/binder/mod.rs similarity index 99% rename from thaw/src/components/binder/mod.rs rename to thaw_components/src/binder/mod.rs index 26f7b0d..4003a4b 100644 --- a/thaw/src/components/binder/mod.rs +++ b/thaw_components/src/binder/mod.rs @@ -2,7 +2,7 @@ mod get_placement_style; pub use get_placement_style::FollowerPlacement; -use crate::components::Teleport; +use crate::Teleport; use get_placement_style::{get_follower_placement_offset, FollowerPlacementOffset}; use leptos::{ html::{AnyElement, ElementDescriptor, ToHtmlElement}, diff --git a/thaw/src/components/css_transition/mod.rs b/thaw_components/src/css_transition/mod.rs similarity index 100% rename from thaw/src/components/css_transition/mod.rs rename to thaw_components/src/css_transition/mod.rs diff --git a/thaw/src/components/if_comp.rs b/thaw_components/src/if_comp.rs similarity index 100% rename from thaw/src/components/if_comp.rs rename to thaw_components/src/if_comp.rs diff --git a/thaw_components/src/lib.rs b/thaw_components/src/lib.rs new file mode 100644 index 0000000..c5f2e01 --- /dev/null +++ b/thaw_components/src/lib.rs @@ -0,0 +1,20 @@ +mod binder; +mod css_transition; +mod if_comp; +mod option_comp; +mod teleport; +mod wave; + +pub use binder::{Binder, Follower, FollowerPlacement, FollowerWidth}; +pub use css_transition::CSSTransition; +pub use if_comp::{ElseIf, If, Then}; +pub use option_comp::OptionComp; +pub use teleport::Teleport; +pub use wave::{Wave, WaveRef}; + +use leptos::*; + +#[slot] +pub struct Fallback { + children: ChildrenFn, +} diff --git a/thaw/src/components/option_comp.rs b/thaw_components/src/option_comp.rs similarity index 100% rename from thaw/src/components/option_comp.rs rename to thaw_components/src/option_comp.rs diff --git a/thaw/src/components/teleport/mod.rs b/thaw_components/src/teleport/mod.rs similarity index 100% rename from thaw/src/components/teleport/mod.rs rename to thaw_components/src/teleport/mod.rs diff --git a/thaw/src/components/wave/mod.rs b/thaw_components/src/wave/mod.rs similarity index 100% rename from thaw/src/components/wave/mod.rs rename to thaw_components/src/wave/mod.rs diff --git a/thaw/src/components/wave/wave.css b/thaw_components/src/wave/wave.css similarity index 100% rename from thaw/src/components/wave/wave.css rename to thaw_components/src/wave/wave.css diff --git a/thaw_utils/src/lib.rs b/thaw_utils/src/lib.rs index 90fedf5..58f7157 100644 --- a/thaw_utils/src/lib.rs +++ b/thaw_utils/src/lib.rs @@ -6,7 +6,7 @@ mod optional_prop; mod signals; mod time; -pub use event_listener::*; +pub use event_listener::{add_event_listener, EventListenerHandle}; pub use hooks::{use_click_position, use_lock_html_scroll}; pub use mount_style::mount_style; pub use optional_prop::OptionalProp;