- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 576
Mobile Web Terminal and Responsive Text
jQuery Terminal works out of the box on mobile. Be sure to not use examples that may hang around somewhere that use onBlur event function and return false. This will prevent the keyboard on mobile from popup because it will keep the terminal in focus and on mobile the terminal has to be disabled on init so you can activate it with a finger tap.
  $('body').terminal(..., {
-     onBlur: function() {
-         return false;
-     }
  });You can use this responsive CSS to make the size of the font change to make to better fit into the screen size:
@media screen and (min-width: 1200px) {
    :root {
        --size: 1.4;
    }
}If you want the text to respond to the size of the terminal, like with default greetings. You can echo a function where you will check the size of the terminal and render proper text. An example is the rendering of fliglet, Where you wrap the text depending on the size of the terminal.
term.echo(function() {
   if (this.cols() > 100) { 
      return bigText();
   } else {
      return smallerText();
   }
});You can return a string, an array of strings, or a Promise of them.
You can see how this works in:
When you use formatting that changes size, example using XML Formatting <font> tag. You need to divide the cols() by the size factor.
const scale = 1.5;
const cols = Math.floor(this.cols() / scale);See example in Figlet XML tag demo.
Library for Web-Based Terminal in JavaScript, (jQuery Terminal: git repo)
Copyright (c) 2011-2023 Jakub T. Jankiewicz