Add LanguageSelector component

This commit is contained in:
Marshall Bowers 2023-10-09 11:39:42 -04:00
parent 06b0707aa9
commit 000ae27aff
5 changed files with 73 additions and 0 deletions

View file

@ -7,6 +7,7 @@ pub mod command_palette;
pub mod context_menu; pub mod context_menu;
pub mod facepile; pub mod facepile;
pub mod keybinding; pub mod keybinding;
pub mod language_selector;
pub mod multi_buffer; pub mod multi_buffer;
pub mod palette; pub mod palette;
pub mod panel; pub mod panel;

View file

@ -0,0 +1,26 @@
use std::marker::PhantomData;
use ui::prelude::*;
use ui::LanguageSelector;
use crate::story::Story;
#[derive(Element)]
pub struct LanguageSelectorStory<S: 'static + Send + Sync + Clone> {
state_type: PhantomData<S>,
}
impl<S: 'static + Send + Sync + Clone> LanguageSelectorStory<S> {
pub fn new() -> Self {
Self {
state_type: PhantomData,
}
}
fn render(&mut self, cx: &mut ViewContext<S>) -> impl Element<State = S> {
Story::container(cx)
.child(Story::title_for::<_, LanguageSelector<S>>(cx))
.child(Story::label(cx, "Default"))
.child(LanguageSelector::new())
}
}

View file

@ -45,6 +45,7 @@ pub enum ComponentStory {
ContextMenu, ContextMenu,
Facepile, Facepile,
Keybinding, Keybinding,
LanguageSelector,
MultiBuffer, MultiBuffer,
Palette, Palette,
Panel, Panel,
@ -77,6 +78,9 @@ impl ComponentStory {
Self::ContextMenu => components::context_menu::ContextMenuStory::new().into_any(), Self::ContextMenu => components::context_menu::ContextMenuStory::new().into_any(),
Self::Facepile => components::facepile::FacepileStory::new().into_any(), Self::Facepile => components::facepile::FacepileStory::new().into_any(),
Self::Keybinding => components::keybinding::KeybindingStory::new().into_any(), Self::Keybinding => components::keybinding::KeybindingStory::new().into_any(),
Self::LanguageSelector => {
components::language_selector::LanguageSelectorStory::new().into_any()
}
Self::MultiBuffer => components::multi_buffer::MultiBufferStory::new().into_any(), Self::MultiBuffer => components::multi_buffer::MultiBufferStory::new().into_any(),
Self::Palette => components::palette::PaletteStory::new().into_any(), Self::Palette => components::palette::PaletteStory::new().into_any(),
Self::Panel => components::panel::PanelStory::new().into_any(), Self::Panel => components::panel::PanelStory::new().into_any(),

View file

@ -9,6 +9,7 @@ mod editor_pane;
mod facepile; mod facepile;
mod icon_button; mod icon_button;
mod keybinding; mod keybinding;
mod language_selector;
mod list; mod list;
mod multi_buffer; mod multi_buffer;
mod palette; mod palette;
@ -37,6 +38,7 @@ pub use editor_pane::*;
pub use facepile::*; pub use facepile::*;
pub use icon_button::*; pub use icon_button::*;
pub use keybinding::*; pub use keybinding::*;
pub use language_selector::*;
pub use list::*; pub use list::*;
pub use multi_buffer::*; pub use multi_buffer::*;
pub use palette::*; pub use palette::*;

View file

@ -0,0 +1,40 @@
use std::marker::PhantomData;
use crate::prelude::*;
use crate::{OrderMethod, Palette, PaletteItem};
#[derive(Element)]
pub struct LanguageSelector<S: 'static + Send + Sync + Clone> {
state_type: PhantomData<S>,
scroll_state: ScrollState,
}
impl<S: 'static + Send + Sync + Clone> LanguageSelector<S> {
pub fn new() -> Self {
Self {
state_type: PhantomData,
scroll_state: ScrollState::default(),
}
}
fn render(&mut self, cx: &mut ViewContext<S>) -> impl Element<State = S> {
div().child(
Palette::new(self.scroll_state.clone())
.items(vec![
PaletteItem::new("C"),
PaletteItem::new("C++"),
PaletteItem::new("CSS"),
PaletteItem::new("Elixir"),
PaletteItem::new("Elm"),
PaletteItem::new("ERB"),
PaletteItem::new("Rust (current)"),
PaletteItem::new("Scheme"),
PaletteItem::new("TOML"),
PaletteItem::new("TypeScript"),
])
.placeholder("Select a language...")
.empty_string("No matches")
.default_order(OrderMethod::Ascending),
)
}
}