mirror of
https://github.com/zed-industries/zed.git
synced 2024-12-01 04:28:57 +00:00
Add pages to theme_preview (#20185)
Added some simple logic + an example of adding pages to the theme preview. Will be used for organizing theme preview sections. Release Notes: - N/A
This commit is contained in:
parent
7025d3f29d
commit
e1cb8a66f0
3 changed files with 91 additions and 6 deletions
1
Cargo.lock
generated
1
Cargo.lock
generated
|
@ -14776,6 +14776,7 @@ dependencies = [
|
||||||
"settings",
|
"settings",
|
||||||
"smallvec",
|
"smallvec",
|
||||||
"sqlez",
|
"sqlez",
|
||||||
|
"strum 0.25.0",
|
||||||
"task",
|
"task",
|
||||||
"tempfile",
|
"tempfile",
|
||||||
"theme",
|
"theme",
|
||||||
|
|
|
@ -61,6 +61,7 @@ theme.workspace = true
|
||||||
ui.workspace = true
|
ui.workspace = true
|
||||||
util.workspace = true
|
util.workspace = true
|
||||||
uuid.workspace = true
|
uuid.workspace = true
|
||||||
|
strum.workspace = true
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
call = { workspace = true, features = ["test-support"] }
|
call = { workspace = true, features = ["test-support"] }
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#![allow(unused, dead_code)]
|
#![allow(unused, dead_code)]
|
||||||
use gpui::{actions, AppContext, EventEmitter, FocusHandle, FocusableView, Hsla};
|
use gpui::{actions, AppContext, EventEmitter, FocusHandle, FocusableView, Hsla};
|
||||||
|
use strum::IntoEnumIterator;
|
||||||
use theme::all_theme_colors;
|
use theme::all_theme_colors;
|
||||||
use ui::{
|
use ui::{
|
||||||
prelude::*, utils::calculate_contrast_ratio, AudioStatus, Availability, Avatar,
|
prelude::*, utils::calculate_contrast_ratio, AudioStatus, Availability, Avatar,
|
||||||
|
@ -21,16 +22,44 @@ pub fn init(cx: &mut AppContext) {
|
||||||
.detach();
|
.detach();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, Copy, PartialEq, PartialOrd, strum::EnumIter)]
|
||||||
|
enum ThemePreviewPage {
|
||||||
|
Overview,
|
||||||
|
Typography,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ThemePreviewPage {
|
||||||
|
pub fn name(&self) -> &'static str {
|
||||||
|
match self {
|
||||||
|
Self::Overview => "Overview",
|
||||||
|
Self::Typography => "Typography",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
struct ThemePreview {
|
struct ThemePreview {
|
||||||
|
current_page: ThemePreviewPage,
|
||||||
focus_handle: FocusHandle,
|
focus_handle: FocusHandle,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ThemePreview {
|
impl ThemePreview {
|
||||||
pub fn new(cx: &mut ViewContext<Self>) -> Self {
|
pub fn new(cx: &mut ViewContext<Self>) -> Self {
|
||||||
Self {
|
Self {
|
||||||
|
current_page: ThemePreviewPage::Overview,
|
||||||
focus_handle: cx.focus_handle(),
|
focus_handle: cx.focus_handle(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn view(
|
||||||
|
&self,
|
||||||
|
page: ThemePreviewPage,
|
||||||
|
cx: &mut ViewContext<ThemePreview>,
|
||||||
|
) -> impl IntoElement {
|
||||||
|
match page {
|
||||||
|
ThemePreviewPage::Overview => self.render_overview_page(cx).into_any_element(),
|
||||||
|
ThemePreviewPage::Typography => self.render_typography_page(cx).into_any_element(),
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl EventEmitter<()> for ThemePreview {}
|
impl EventEmitter<()> for ThemePreview {}
|
||||||
|
@ -432,23 +461,77 @@ impl ThemePreview {
|
||||||
.child(self.render_text(layer, cx))
|
.child(self.render_text(layer, cx))
|
||||||
.child(self.render_colors(layer, cx))
|
.child(self.render_colors(layer, cx))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn render_overview_page(&self, cx: &ViewContext<Self>) -> impl IntoElement {
|
||||||
|
v_flex()
|
||||||
|
.id("theme-preview-overview")
|
||||||
|
.overflow_scroll()
|
||||||
|
.size_full()
|
||||||
|
.child(
|
||||||
|
v_flex()
|
||||||
|
.child(Headline::new("Theme Preview").size(HeadlineSize::Large))
|
||||||
|
.child(div().w_full().text_color(cx.theme().colors().text_muted).child("This view lets you preview a range of UI elements across a theme. Use it for testing out changes to the theme."))
|
||||||
|
)
|
||||||
|
.child(self.render_theme_layer(ElevationIndex::Background, cx))
|
||||||
|
.child(self.render_theme_layer(ElevationIndex::Surface, cx))
|
||||||
|
.child(self.render_theme_layer(ElevationIndex::EditorSurface, cx))
|
||||||
|
.child(self.render_theme_layer(ElevationIndex::ElevatedSurface, cx))
|
||||||
|
}
|
||||||
|
|
||||||
|
fn render_typography_page(&self, cx: &ViewContext<Self>) -> impl IntoElement {
|
||||||
|
v_flex()
|
||||||
|
.id("theme-preview-typography")
|
||||||
|
.overflow_scroll()
|
||||||
|
.size_full()
|
||||||
|
.child(v_flex()
|
||||||
|
.gap_4()
|
||||||
|
.child(Headline::new("Headline 1").size(HeadlineSize::XLarge))
|
||||||
|
.child(Label::new("Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua."))
|
||||||
|
.child(Headline::new("Headline 2").size(HeadlineSize::Large))
|
||||||
|
.child(Label::new("Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat."))
|
||||||
|
.child(Headline::new("Headline 3").size(HeadlineSize::Medium))
|
||||||
|
.child(Label::new("Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur."))
|
||||||
|
.child(Headline::new("Headline 4").size(HeadlineSize::Small))
|
||||||
|
.child(Label::new("Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."))
|
||||||
|
.child(Headline::new("Headline 5").size(HeadlineSize::XSmall))
|
||||||
|
.child(Label::new("Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat."))
|
||||||
|
.child(Headline::new("Body Text").size(HeadlineSize::Small))
|
||||||
|
.child(Label::new("Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."))
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Render for ThemePreview {
|
impl Render for ThemePreview {
|
||||||
fn render(&mut self, cx: &mut ViewContext<Self>) -> impl ui::IntoElement {
|
fn render(&mut self, cx: &mut ViewContext<Self>) -> impl ui::IntoElement {
|
||||||
v_flex()
|
h_flex()
|
||||||
.id("theme-preview")
|
.id("theme-preview")
|
||||||
.key_context("ThemePreview")
|
.key_context("ThemePreview")
|
||||||
.overflow_scroll()
|
.items_start()
|
||||||
|
.overflow_hidden()
|
||||||
.size_full()
|
.size_full()
|
||||||
.max_h_full()
|
.max_h_full()
|
||||||
.p_4()
|
.p_4()
|
||||||
.track_focus(&self.focus_handle)
|
.track_focus(&self.focus_handle)
|
||||||
.bg(Self::preview_bg(cx))
|
.bg(Self::preview_bg(cx))
|
||||||
.gap_4()
|
.gap_4()
|
||||||
.child(self.render_theme_layer(ElevationIndex::Background, cx))
|
.child(
|
||||||
.child(self.render_theme_layer(ElevationIndex::Surface, cx))
|
v_flex()
|
||||||
.child(self.render_theme_layer(ElevationIndex::EditorSurface, cx))
|
.items_start()
|
||||||
.child(self.render_theme_layer(ElevationIndex::ElevatedSurface, cx))
|
.gap_1()
|
||||||
|
.w(px(240.))
|
||||||
|
.child(
|
||||||
|
v_flex()
|
||||||
|
.gap_px()
|
||||||
|
.children(ThemePreviewPage::iter().map(|p| {
|
||||||
|
Button::new(ElementId::Name(p.name().into()), p.name())
|
||||||
|
.on_click(cx.listener(move |this, _, cx| {
|
||||||
|
this.current_page = p;
|
||||||
|
cx.notify();
|
||||||
|
}))
|
||||||
|
.selected(p == self.current_page)
|
||||||
|
})),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
.child(self.view(self.current_page, cx))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue