Fix notification styling, minimize database reads

This commit is contained in:
Mikayla Maki 2023-05-31 13:56:41 -07:00
parent c9820fde61
commit ef80b539d1
No known key found for this signature in database
2 changed files with 76 additions and 19 deletions

View file

@ -33,7 +33,7 @@ impl From<&dyn NotificationHandle> for AnyViewHandle {
} }
} }
struct NotificationTracker { pub(crate) struct NotificationTracker {
notifications_sent: HashMap<TypeId, Vec<usize>>, notifications_sent: HashMap<TypeId, Vec<usize>>,
} }
@ -65,8 +65,7 @@ impl Workspace {
id: usize, id: usize,
cx: &ViewContext<Self>, cx: &ViewContext<Self>,
) -> bool { ) -> bool {
cx cx.global::<NotificationTracker>()
.global::<NotificationTracker>()
.get(&TypeId::of::<V>()) .get(&TypeId::of::<V>())
.map(|ids| ids.contains(&id)) .map(|ids| ids.contains(&id))
.unwrap_or(false) .unwrap_or(false)
@ -78,8 +77,7 @@ impl Workspace {
cx: &mut ViewContext<Self>, cx: &mut ViewContext<Self>,
build_notification: impl FnOnce(&mut ViewContext<Self>) -> ViewHandle<V>, build_notification: impl FnOnce(&mut ViewContext<Self>) -> ViewHandle<V>,
) { ) {
if !self.has_shown_notification_once::<V>(id, cx) if !self.has_shown_notification_once::<V>(id, cx) {
{
cx.update_global::<NotificationTracker, _, _>(|tracker, _| { cx.update_global::<NotificationTracker, _, _>(|tracker, _| {
let entry = tracker.entry(TypeId::of::<V>()).or_default(); let entry = tracker.entry(TypeId::of::<V>()).or_default();
entry.push(id); entry.push(id);
@ -167,7 +165,7 @@ pub mod simple_message_notification {
elements::{Flex, MouseEventHandler, Padding, ParentElement, Svg, Text}, elements::{Flex, MouseEventHandler, Padding, ParentElement, Svg, Text},
impl_actions, impl_actions,
platform::{CursorStyle, MouseButton}, platform::{CursorStyle, MouseButton},
AppContext, Element, Entity, View, ViewContext, AnyElement, AppContext, Element, Entity, View, ViewContext, fonts::TextStyle,
}; };
use menu::Cancel; use menu::Cancel;
use serde::Deserialize; use serde::Deserialize;
@ -195,8 +193,13 @@ pub mod simple_message_notification {
) )
} }
enum NotificationMessage {
Text(Cow<'static, str>),
Element(fn(TextStyle, &AppContext) -> AnyElement<MessageNotification>),
}
pub struct MessageNotification { pub struct MessageNotification {
message: Cow<'static, str>, message: NotificationMessage,
on_click: Option<Arc<dyn Fn(&mut ViewContext<Self>)>>, on_click: Option<Arc<dyn Fn(&mut ViewContext<Self>)>>,
click_message: Option<Cow<'static, str>>, click_message: Option<Cow<'static, str>>,
} }
@ -215,7 +218,16 @@ pub mod simple_message_notification {
S: Into<Cow<'static, str>>, S: Into<Cow<'static, str>>,
{ {
Self { Self {
message: message.into(), message: NotificationMessage::Text(message.into()),
on_click: None,
click_message: None,
}
}
pub fn new_element(message: fn(TextStyle, &AppContext) -> AnyElement<MessageNotification>) -> MessageNotification
{
Self {
message: NotificationMessage::Element(message),
on_click: None, on_click: None,
click_message: None, click_message: None,
} }
@ -254,7 +266,12 @@ pub mod simple_message_notification {
enum MessageNotificationTag {} enum MessageNotificationTag {}
let click_message = self.click_message.clone(); let click_message = self.click_message.clone();
let message = self.message.clone(); let message = match &self.message {
NotificationMessage::Text(text) => {
Text::new(text.to_owned(), theme.message.text.clone()).into_any()
}
NotificationMessage::Element(e) => e(theme.message.text.clone(), cx),
};
let on_click = self.on_click.clone(); let on_click = self.on_click.clone();
let has_click_action = on_click.is_some(); let has_click_action = on_click.is_some();
@ -262,8 +279,7 @@ pub mod simple_message_notification {
.with_child( .with_child(
Flex::row() Flex::row()
.with_child( .with_child(
Text::new(message, theme.message.text.clone()) message.contained()
.contained()
.with_style(theme.message.container) .with_style(theme.message.container)
.aligned() .aligned()
.top() .top()

View file

@ -19,7 +19,7 @@ use assets::Assets;
use call::ActiveCall; use call::ActiveCall;
use client::{ use client::{
proto::{self, PeerId}, proto::{self, PeerId},
Client, TypedEnvelope, UserStore, ZED_APP_VERSION, Client, TypedEnvelope, UserStore,
}; };
use collections::{hash_map, HashMap, HashSet}; use collections::{hash_map, HashMap, HashSet};
use drag_and_drop::DragAndDrop; use drag_and_drop::DragAndDrop;
@ -60,7 +60,7 @@ use std::{
}; };
use crate::{ use crate::{
notifications::simple_message_notification::MessageNotification, notifications::{simple_message_notification::MessageNotification, NotificationTracker},
persistence::model::{ persistence::model::{
DockData, DockStructure, SerializedPane, SerializedPaneGroup, SerializedWorkspace, DockData, DockStructure, SerializedPane, SerializedPaneGroup, SerializedWorkspace,
}, },
@ -81,7 +81,7 @@ use serde::Deserialize;
use shared_screen::SharedScreen; use shared_screen::SharedScreen;
use status_bar::StatusBar; use status_bar::StatusBar;
pub use status_bar::StatusItemView; pub use status_bar::StatusItemView;
use theme::Theme; use theme::{Theme, ThemeSettings};
pub use toolbar::{ToolbarItemLocation, ToolbarItemView}; pub use toolbar::{ToolbarItemLocation, ToolbarItemView};
use util::{async_iife, channel::ZedVersion, paths, ResultExt}; use util::{async_iife, channel::ZedVersion, paths, ResultExt};
pub use workspace_settings::{AutosaveSetting, GitGutterSetting, WorkspaceSettings}; pub use workspace_settings::{AutosaveSetting, GitGutterSetting, WorkspaceSettings};
@ -3193,6 +3193,7 @@ async fn open_items(
fn notify_of_new_dock(workspace: &WeakViewHandle<Workspace>, cx: &mut AsyncAppContext) { fn notify_of_new_dock(workspace: &WeakViewHandle<Workspace>, cx: &mut AsyncAppContext) {
const NEW_PANEL_BLOG_POST: &str = "https://zed.dev/blog/new-panel-system"; const NEW_PANEL_BLOG_POST: &str = "https://zed.dev/blog/new-panel-system";
const NEW_DOCK_HINT_KEY: &str = "show_new_dock_key"; const NEW_DOCK_HINT_KEY: &str = "show_new_dock_key";
const MESSAGE_ID: usize = 2;
if workspace if workspace
.read_with(cx, |workspace, cx| { .read_with(cx, |workspace, cx| {
@ -3205,7 +3206,7 @@ fn notify_of_new_dock(workspace: &WeakViewHandle<Workspace>, cx: &mut AsyncAppCo
{ {
return true; return true;
} }
workspace.has_shown_notification_once::<MessageNotification>(2, cx) workspace.has_shown_notification_once::<MessageNotification>(MESSAGE_ID, cx)
}) })
.unwrap_or(false) .unwrap_or(false)
{ {
@ -3218,6 +3219,24 @@ fn notify_of_new_dock(workspace: &WeakViewHandle<Workspace>, cx: &mut AsyncAppCo
.flatten() .flatten()
.is_some() .is_some()
{ {
if !workspace
.read_with(cx, |workspace, cx| {
workspace.has_shown_notification_once::<MessageNotification>(MESSAGE_ID, cx)
})
.unwrap_or(false)
{
cx.update(|cx| {
cx.update_global::<NotificationTracker, _, _>(|tracker, _| {
let entry = tracker
.entry(TypeId::of::<MessageNotification>())
.or_default();
if !entry.contains(&MESSAGE_ID) {
entry.push(MESSAGE_ID);
}
});
});
}
return; return;
} }
@ -3232,11 +3251,33 @@ fn notify_of_new_dock(workspace: &WeakViewHandle<Workspace>, cx: &mut AsyncAppCo
workspace workspace
.update(cx, |workspace, cx| { .update(cx, |workspace, cx| {
workspace.show_notification_once(2, cx, |cx| { workspace.show_notification_once(2, cx, |cx| {
cx.add_view(|_| { cx.add_view(|_| {
MessageNotification::new( MessageNotification::new_element(|text, _| {
"Looking for the dock? Try 'ctrl-`'!\n'shift-escape' now zooms your pane", Text::new(
) "Looking for the dock? Try ctrl-`!\nshift-escape now zooms your pane.",
.with_click_message("Click to read more about the new panel system") text,
)
.with_custom_runs(vec![26..32, 34..46], |_, bounds, scene, cx| {
let code_span_background_color = settings::get::<ThemeSettings>(cx)
.theme
.editor
.document_highlight_read_background;
scene.push_quad(gpui::Quad {
bounds,
background: Some(code_span_background_color),
border: Default::default(),
corner_radius: 2.0,
})
})
.into_any()
})
// MessageNotification::new_(
// "Looking for the dock? Try 'ctrl-`'!\n'shift-escape' now zooms your pane",
// )
.with_click_message("Read more about the new panel system")
.on_click(|cx| cx.platform().open_url(NEW_PANEL_BLOG_POST)) .on_click(|cx| cx.platform().open_url(NEW_PANEL_BLOG_POST))
}) })
}) })