Work on sample collab_panel
story in the storybook
Co-Authored-By: Nathan Sobo <1789+nathansobo@users.noreply.github.com>
This commit is contained in:
parent
e08c0fc4ce
commit
0695e8d3b9
4 changed files with 117 additions and 10 deletions
|
@ -62,6 +62,21 @@ enum ElementPhase<V: 'static, E: Element<V>> {
|
||||||
Error(String),
|
Error(String),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<V: 'static, E: Element<V>> std::fmt::Debug for ElementPhase<V, E> {
|
||||||
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
|
match self {
|
||||||
|
ElementPhase::Init => write!(f, "Init"),
|
||||||
|
ElementPhase::PostLayout { layout_id, .. } => {
|
||||||
|
write!(f, "PostLayout with layout id: {:?}", layout_id)
|
||||||
|
}
|
||||||
|
ElementPhase::PostPaint { layout, .. } => {
|
||||||
|
write!(f, "PostPaint with layout: {:?}", layout)
|
||||||
|
}
|
||||||
|
ElementPhase::Error(err) => write!(f, "Error: {}", err),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl<V: 'static, E: Element<V>> Default for ElementPhase<V, E> {
|
impl<V: 'static, E: Element<V>> Default for ElementPhase<V, E> {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self::Init
|
Self::Init
|
||||||
|
@ -105,8 +120,22 @@ impl<V, E: Element<V>> AnyStatefulElement<V> for StatefulElement<V, E> {
|
||||||
}
|
}
|
||||||
Err(error) => ElementPhase::Error(error.to_string()),
|
Err(error) => ElementPhase::Error(error.to_string()),
|
||||||
},
|
},
|
||||||
|
ElementPhase::PostPaint {
|
||||||
|
mut layout,
|
||||||
|
mut paint_state,
|
||||||
|
} => {
|
||||||
|
layout.bounds = layout.bounds + parent_origin;
|
||||||
|
self.element.paint(view, &layout, &mut paint_state, cx);
|
||||||
|
ElementPhase::PostPaint {
|
||||||
|
layout,
|
||||||
|
paint_state,
|
||||||
|
}
|
||||||
|
}
|
||||||
phase @ ElementPhase::Error(_) => phase,
|
phase @ ElementPhase::Error(_) => phase,
|
||||||
_ => panic!("invalid element phase to call paint"),
|
|
||||||
|
phase @ _ => {
|
||||||
|
panic!("invalid element phase to call paint: {:?}", phase);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -268,14 +268,14 @@ pub trait Styleable {
|
||||||
Self::Style::from_refinement(&self.style_cascade().merged())
|
Self::Style::from_refinement(&self.style_cascade().merged())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn hovered(self) -> Hoverable<Self>
|
fn hover(self) -> Hoverable<Self>
|
||||||
where
|
where
|
||||||
Self: Sized,
|
Self: Sized,
|
||||||
{
|
{
|
||||||
hoverable(self)
|
hoverable(self)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn pressed(self) -> Pressable<Self>
|
fn active(self) -> Pressable<Self>
|
||||||
where
|
where
|
||||||
Self: Sized,
|
Self: Sized,
|
||||||
{
|
{
|
||||||
|
|
|
@ -68,8 +68,11 @@ fn tailwind_lengths() -> Vec<(&'static str, TokenStream2)> {
|
||||||
("4", quote! { rems(1.) }),
|
("4", quote! { rems(1.) }),
|
||||||
("5", quote! { rems(1.25) }),
|
("5", quote! { rems(1.25) }),
|
||||||
("6", quote! { rems(1.5) }),
|
("6", quote! { rems(1.5) }),
|
||||||
|
("7", quote! { rems(1.75) }),
|
||||||
("8", quote! { rems(2.0) }),
|
("8", quote! { rems(2.0) }),
|
||||||
|
("9", quote! { rems(2.25) }),
|
||||||
("10", quote! { rems(2.5) }),
|
("10", quote! { rems(2.5) }),
|
||||||
|
("11", quote! { rems(2.75) }),
|
||||||
("12", quote! { rems(3.) }),
|
("12", quote! { rems(3.) }),
|
||||||
("16", quote! { rems(4.) }),
|
("16", quote! { rems(4.) }),
|
||||||
("20", quote! { rems(5.) }),
|
("20", quote! { rems(5.) }),
|
||||||
|
@ -149,5 +152,12 @@ fn tailwind_prefixes() -> Vec<(&'static str, bool, Vec<TokenStream2>)> {
|
||||||
("bottom", true, vec![quote! { inset.bottom }]),
|
("bottom", true, vec![quote! { inset.bottom }]),
|
||||||
("left", true, vec![quote! { inset.left }]),
|
("left", true, vec![quote! { inset.left }]),
|
||||||
("right", true, vec![quote! { inset.right }]),
|
("right", true, vec![quote! { inset.right }]),
|
||||||
|
(
|
||||||
|
"gap",
|
||||||
|
false,
|
||||||
|
vec![quote! { gap.width }, quote! { gap.height }],
|
||||||
|
),
|
||||||
|
("gap_x", false, vec![quote! { gap.width }]),
|
||||||
|
("gap_y", false, vec![quote! { gap.height }]),
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,9 @@
|
||||||
use crate::theme::theme;
|
use crate::theme::theme;
|
||||||
use gpui2::{elements::div, style::StyleHelpers, Element, IntoElement, ParentElement, ViewContext};
|
use gpui2::{
|
||||||
|
elements::div,
|
||||||
|
style::{StyleHelpers, Styleable},
|
||||||
|
Element, IntoElement, ParentElement, ViewContext,
|
||||||
|
};
|
||||||
use std::marker::PhantomData;
|
use std::marker::PhantomData;
|
||||||
|
|
||||||
#[derive(Element)]
|
#[derive(Element)]
|
||||||
|
@ -13,23 +17,87 @@ pub fn collab_panel<V: 'static>() -> CollabPanelElement<V> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// fn list_item<V: 'static>(cx: &mut ViewContext<V>) -> impl IntoElement<V> {
|
||||||
|
// let theme = theme(cx);
|
||||||
|
// div()
|
||||||
|
// .px_2()
|
||||||
|
// .flex()
|
||||||
|
// .justify_between()
|
||||||
|
// //:: States - https://tailwindcss.com/docs/hover-focus-and-other-states#hover-focus-and-active
|
||||||
|
// .hover()
|
||||||
|
// .fill(theme.middle.variant.hovered.background)
|
||||||
|
// .active()
|
||||||
|
// .fill(theme.middle.variant.pressed.background)
|
||||||
|
// .child(div().flex().gap_1().child("#").child("Collab Panel"))
|
||||||
|
// .child(div().flex().gap_1().child("v"))
|
||||||
|
// }
|
||||||
|
|
||||||
|
// Macros to impl:
|
||||||
|
// - border (b, t, l, r, x, y)
|
||||||
|
// - border_[foo]_[size] (border_b_2, border_t_4, etc)
|
||||||
|
// - border_color
|
||||||
|
// - items_[center, start, end]
|
||||||
|
|
||||||
impl<V: 'static> CollabPanelElement<V> {
|
impl<V: 'static> CollabPanelElement<V> {
|
||||||
fn render(&mut self, _: &mut V, cx: &mut ViewContext<V>) -> impl IntoElement<V> {
|
fn render(&mut self, _: &mut V, cx: &mut ViewContext<V>) -> impl IntoElement<V> {
|
||||||
let theme = theme(cx);
|
let theme = theme(cx);
|
||||||
|
|
||||||
|
// Panel
|
||||||
div()
|
div()
|
||||||
.full()
|
.full()
|
||||||
.font("Zed Sans")
|
.font("Zed Sans")
|
||||||
.text_color(theme.middle.variant.default.foreground)
|
.text_color(theme.middle.variant.default.foreground)
|
||||||
|
// .border_color(theme.middle.base.default.border)
|
||||||
.fill(theme.middle.base.default.background)
|
.fill(theme.middle.base.default.background)
|
||||||
.py_2()
|
// List Container
|
||||||
.child(
|
.child(
|
||||||
div()
|
div()
|
||||||
.px_2()
|
.full()
|
||||||
.flex()
|
.fill(theme.middle.variant.default.background)
|
||||||
.justify_between()
|
.py_2()
|
||||||
.child("#CRDB")
|
// .border_b()
|
||||||
.child("V"),
|
//:: https://tailwindcss.com/docs/hover-focus-and-other-states#styling-based-on-parent-state
|
||||||
|
// .group()
|
||||||
|
// List Section Header
|
||||||
|
.child(
|
||||||
|
div()
|
||||||
|
.px_2()
|
||||||
|
.flex()
|
||||||
|
.justify_between()
|
||||||
|
//:: States - https://tailwindcss.com/docs/hover-focus-and-other-states#hover-focus-and-active
|
||||||
|
.hover()
|
||||||
|
.fill(theme.middle.variant.hovered.background)
|
||||||
|
// .focus().fill(theme.middle.variant.active.background)
|
||||||
|
.active()
|
||||||
|
.fill(theme.middle.variant.pressed.background)
|
||||||
|
.child(
|
||||||
|
div()
|
||||||
|
.flex()
|
||||||
|
.gap_1()
|
||||||
|
//:: State based on group interaction state
|
||||||
|
// .group_hover().text_color(theme.middle.variant.hovered.foreground)
|
||||||
|
.child("#")
|
||||||
|
.child("Collab Panel"),
|
||||||
|
)
|
||||||
|
.child(div().flex().gap_1().child("v")),
|
||||||
|
)
|
||||||
|
// List Item Large
|
||||||
|
.child(
|
||||||
|
div()
|
||||||
|
.px_2()
|
||||||
|
.h_7()
|
||||||
|
.flex()
|
||||||
|
.justify_between()
|
||||||
|
// .items_center()
|
||||||
|
.child(
|
||||||
|
div()
|
||||||
|
.flex()
|
||||||
|
.gap_1()
|
||||||
|
.child(div().w_4().h_4().child("img"))
|
||||||
|
.child("maxbrunsfeld"),
|
||||||
|
)
|
||||||
|
.child(div().flex().gap_2().child("icon")),
|
||||||
|
),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue