Class TerminalUI
java.lang.Object
org.springframework.shell.component.view.TerminalUI
- All Implemented Interfaces:
- ViewService
TerminalUI is a main component orchestrating terminal, eventloop,
 key/mouse events and view structure to work together. In many ways it can
 be think of being a "main application" when terminal ui is shown in
 a screen.- 
Constructor SummaryConstructorsConstructorDescriptionTerminalUI(org.jline.terminal.Terminal terminal) Constructs a handler with a given terminal.
- 
Method SummaryModifier and TypeMethodDescriptionvoidGets anEventLoop.getModal()Gets a current modal view.Gets atheme name.Sets aThemeResolver.Gets aViewService.voidredraw()Redraw a whole screen.voidrun()Run and start execution loop.voidSets a view to be focused.voidsetFullScreenViewRect(BiFunction<org.jline.terminal.Terminal, View, Rectangle> fullScreenViewRect) Sets a view rect function for full screen mode.voidSets a new modal view.voidsetNonfullScreenViewRect(BiFunction<org.jline.terminal.Terminal, View, Rectangle> nonfullScreenViewRect) Sets a view rect function for full screen mode.voidSets a root view.voidsetThemeName(String themeName) Sets atheme name.voidsetThemeResolver(ThemeResolver themeResolver) Sets aThemeResolver.
- 
Constructor Details- 
TerminalUIpublic TerminalUI(org.jline.terminal.Terminal terminal) Constructs a handler with a given terminal.- Parameters:
- terminal- the terminal
 
 
- 
- 
Method Details- 
getModalDescription copied from interface:ViewServiceGets a current modal view.- Specified by:
- getModalin interface- ViewService
- Returns:
- current modal view
 
- 
setModalDescription copied from interface:ViewServiceSets a new modal view. Setting modal tonullclears existing modal.- Specified by:
- setModalin interface- ViewService
- Parameters:
- view- a view to use as modal
 
- 
setRootSets a root view.- Parameters:
- root- the root view
- fullScreen- if root view should request full screen
 
- 
runpublic void run()Run and start execution loop. This method blocks until run loop exits.
- 
getEventLoopGets anEventLoop.- Returns:
- an event loop
 
- 
redrawpublic void redraw()Redraw a whole screen. Essentially a message is dispatched to an event loop which is handled as soon as possible.
- 
setThemeResolverSets aThemeResolver.- Parameters:
- themeResolver- the theme resolver
 
- 
getThemeResolverSets aThemeResolver.- Returns:
- a theme resolver
 
- 
setThemeNameSets atheme name.- Parameters:
- themeName- the theme name
 
- 
getThemeNameGets atheme name.- Returns:
- a theme name
 
- 
getViewServiceGets aViewService.- Returns:
- a view service
 
- 
configure- Parameters:
- view- the view to configure
 
- 
setFocusDescription copied from interface:ViewServiceSets a view to be focused. Setting focus tonullclears focused view.- Specified by:
- setFocusin interface- ViewService
- Parameters:
- view- a view to be focused
 
- 
setFullScreenViewRectpublic void setFullScreenViewRect(BiFunction<org.jline.terminal.Terminal, View, Rectangle> fullScreenViewRect) Sets a view rect function for full screen mode. Default behaviour usesRectanglearea equal to terminal size.- Parameters:
- fullScreenViewRect- the view rect function
 
- 
setNonfullScreenViewRectpublic void setNonfullScreenViewRect(BiFunction<org.jline.terminal.Terminal, View, Rectangle> nonfullScreenViewRect) Sets a view rect function for full screen mode. Default behaviour usesRectanglefromrootViewif it's not empty, otherwise uses zero based area with width matching terminal columns and height matching 5.- Parameters:
- nonfullScreenViewRect- the view rect function
 
 
-