Skip to content

Commit

Permalink
show placeholder popup when waiting for external editor #157
Browse files Browse the repository at this point in the history
  • Loading branch information
Stephan Dilly committed Jul 4, 2020
1 parent 7016f17 commit de7f48f
Show file tree
Hide file tree
Showing 6 changed files with 118 additions and 3 deletions.
16 changes: 13 additions & 3 deletions src/app.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ use crate::{
cmdbar::CommandBar,
components::{
event_pump, CommandBlocking, CommandInfo, CommitComponent,
Component, DrawableComponent, HelpComponent,
InspectCommitComponent, MsgComponent, ResetComponent,
StashMsgComponent,
Component, DrawableComponent, ExternalEditorComponent,
HelpComponent, InspectCommitComponent, MsgComponent,
ResetComponent, StashMsgComponent,
},
input::{Input, InputEvent, InputState},
keys,
Expand Down Expand Up @@ -35,6 +35,7 @@ pub struct App {
commit: CommitComponent,
stashmsg_popup: StashMsgComponent,
inspect_commit_popup: InspectCommitComponent,
external_editor_popup: ExternalEditorComponent,
cmdbar: RefCell<CommandBar>,
tab: usize,
revlog: Revlog,
Expand Down Expand Up @@ -76,6 +77,9 @@ impl App {
sender,
theme.clone(),
),
external_editor_popup: ExternalEditorComponent::new(
theme.clone(),
),
do_quit: false,
cmdbar: RefCell::new(CommandBar::new(theme.clone())),
help: HelpComponent::new(theme.clone()),
Expand Down Expand Up @@ -190,6 +194,7 @@ impl App {
self.update_commands();
}
} else if let InputEvent::State(polling_state) = ev {
self.external_editor_popup.hide();
if let InputState::Paused = polling_state {
if let Err(e) = self.commit.show_editor() {
let msg =
Expand Down Expand Up @@ -274,6 +279,7 @@ impl App {
commit,
stashmsg_popup,
inspect_commit_popup,
external_editor_popup,
help,
revlog,
status_tab,
Expand Down Expand Up @@ -404,6 +410,8 @@ impl App {
}
InternalEvent::SuspendPolling => {
self.input.set_polling(false);
self.external_editor_popup.show()?;
flags.insert(NeedsUpdate::COMMANDS)
}
};

Expand Down Expand Up @@ -458,6 +466,7 @@ impl App {
|| self.msg.is_visible()
|| self.stashmsg_popup.is_visible()
|| self.inspect_commit_popup.is_visible()
|| self.external_editor_popup.is_visible()
}

fn draw_popups<B: Backend>(
Expand All @@ -481,6 +490,7 @@ impl App {
self.help.draw(f, size)?;
self.msg.draw(f, size)?;
self.inspect_commit_popup.draw(f, size)?;
self.external_editor_popup.draw(f, size)?;

Ok(())
}
Expand Down
2 changes: 2 additions & 0 deletions src/components/commit.rs
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,7 @@ impl Component for CommitComponent {
self.queue
.borrow_mut()
.push_back(InternalEvent::SuspendPolling);
self.hide();
}

_ => (),
Expand Down Expand Up @@ -204,6 +205,7 @@ impl CommitComponent {
let message = message.trim().to_string();

self.input.set_text(message);
self.input.show()?;

Ok(())
}
Expand Down
98 changes: 98 additions & 0 deletions src/components/externaleditor.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
use crate::{
components::{
visibility_blocking, CommandBlocking, CommandInfo, Component,
DrawableComponent,
},
strings,
ui::{self, style::SharedTheme},
};
use anyhow::Result;
use crossterm::event::Event;
use tui::{
backend::Backend,
layout::Rect,
widgets::{Block, BorderType, Borders, Clear, Paragraph, Text},
Frame,
};

///
pub struct ExternalEditorComponent {
visible: bool,
theme: SharedTheme,
}

impl ExternalEditorComponent {
///
pub fn new(theme: SharedTheme) -> Self {
Self {
visible: false,
theme,
}
}
}

impl DrawableComponent for ExternalEditorComponent {
fn draw<B: Backend>(
&self,
f: &mut Frame<B>,
_rect: Rect,
) -> Result<()> {
if self.visible {
let txt =
vec![Text::Raw(strings::MSG_OPENING_EDITOR.into())];

let area = ui::centered_rect_absolute(25, 3, f.size());
f.render_widget(Clear, area);
f.render_widget(
Paragraph::new(txt.iter())
.block(
Block::default()
.borders(Borders::ALL)
.border_type(BorderType::Thick)
.title_style(self.theme.title(true))
.border_style(self.theme.block(true)),
)
.style(self.theme.text_danger()),
area,
);
}

Ok(())
}
}

impl Component for ExternalEditorComponent {
fn commands(
&self,
out: &mut Vec<CommandInfo>,
_force_all: bool,
) -> CommandBlocking {
if self.visible {
out.clear();
}

visibility_blocking(self)
}

fn event(&mut self, _ev: Event) -> Result<bool> {
if self.visible {
return Ok(true);
}

Ok(false)
}

fn is_visible(&self) -> bool {
self.visible
}

fn hide(&mut self) {
self.visible = false
}

fn show(&mut self) -> Result<()> {
self.visible = true;

Ok(())
}
}
2 changes: 2 additions & 0 deletions src/components/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ mod commit;
mod commit_details;
mod commitlist;
mod diff;
mod externaleditor;
mod filetree;
mod help;
mod inspect_commit;
Expand All @@ -22,6 +23,7 @@ pub use commit::CommitComponent;
pub use commit_details::CommitDetailsComponent;
pub use commitlist::CommitList;
pub use diff::DiffComponent;
pub use externaleditor::ExternalEditorComponent;
pub use filetree::FileTreeComponent;
pub use help::HelpComponent;
pub use inspect_commit::InspectCommitComponent;
Expand Down
2 changes: 2 additions & 0 deletions src/queue.rs
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,8 @@ pub enum InternalEvent {
///
InspectCommit(CommitId),
///
//TODO: make this a generic OpenExternalEditor to also use it for other places
//(see https://github.com/extrawurst/gitui/issues/166)
SuspendPolling,
}

Expand Down
1 change: 1 addition & 0 deletions src/strings.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ pub static TAB_DIVIDER: &str = " | ";

pub static CMD_SPLITTER: &str = " ";

pub static MSG_OPENING_EDITOR: &str = "opening editor...";
pub static MSG_TITLE_ERROR: &str = "Error";
pub static COMMIT_TITLE: &str = "Commit";
pub static COMMIT_TITLE_AMEND: &str = "Commit (Amend)";
Expand Down

0 comments on commit de7f48f

Please sign in to comment.