terminalizer-v2 v0.7.3
Terminalizer
Record your terminal and generate animated gif images or share a web player link terminalizer.com
Built to be jusT cOol 👌🦄 !
If you think so, support me with a
starand afollow😘
Built while listening to Nyan Cat 😛
Table of Contents
Features
- Highly customizable.
- Cross platform (Linux, Windows, MacOS).
- Custom window frames.
- Custom font.
- Custom colors.
- Custom styleswithCSS.
- Watermark.
- Edit frames and adjust delays before rendering.
- Skipping frames by a step value to reduce the number of rendered frames.
- Render images with texts on them instead of capturing your screen for better quality.
- The ability to configure:- The command to capture (bash, powershell.exe, yourOwnCommand, etc)
- The current working directory.
- Explicit values for the number of cols and rows.
- GIF quality and repeating.
- Frames delays.
- The max idle time between frames.
- Cursor style.
- Font.
- Font size.
- Line height.
- Letter spacing.
- Theme.
 
What's Next
- The Generatecommand to generate a web player for a recording file.
- Support apt-get,yum,brewinstallation.
Installation
You need to install Node.js first, then install the tool globally using this command:
npm install -g terminalizer-v2Still facing an issue? Check the Issues section or open a new issue.
The installation should be very smooth with Node.js v4-v12. For newer versions, if the installation is failed, you may need to install the development tools to build the C++ add-ons. Check node-gyp.
Getting Started
Start recording your terminal using the record command.
terminalizer-v2 record demoA file called demo.yml will be created in the current directory. You can open it using any editor to edit the configurations and the recorded frames. You can replay your recording using the play command.
terminalizer-v2 play demoNow let's render our recording as an animated gif.
terminalizer-v2 render demoCompression
GIF compression is not implemented yet. For now we recommend https://gifcompressor.com.
Usage
You can use the
--helpoption to get more details about the commands and their options
terminalizer-v2 <command> [options]Init
Create a global config directory
terminalizer-v2 initConfig
Generate a config file in the current directory
terminalizer-v2 configRecord
Record your terminal and create a recording file
terminalizer-v2 record <recordingFile>Options
-c, --config        Overwrite the default configurations                                  [string]
-d, --command       The command to be executed                            [string] [default: null]
-k, --skip-sharing  Skip sharing and showing the sharing prompt message [boolean] [default: false]Examples
terminalizer-v2 record foo                      Start recording and create a recording file called foo.yml
terminalizer-v2 record foo --config config.yml  Start recording with your own configurationsPlay
Play a recording file on your terminal
terminalizer-v2 play <recordingFile>Options
-r, --real-timing   Use the actual delays between frames as recorded        [boolean] [default: false]
-s, --speed-factor  Speed factor, multiply the frames delays by this factor [number] [default: 1]Render
Render a recording file as an animated gif image
terminalizer-v2 render <recordingFile>Options
-o, --output   A name for the output file                                      [string]
-q, --quality  The quality of the rendered image (1 - 100)                     [number]
-s, --step     To reduce the number of rendered frames (step > 1) [number] [default: 1]Share
Upload a recording file and get a link for an online player
terminalizer-v2 share <recordingFile>Generate
Generate a web player for a recording file
terminalizer-v2 generate <recordingFile>Configurations
The default config.yml file is stored under the root directory of the project. Execute the below command to copy it to your current directory.
Use any editor to edit the copied
config.yml, then use the-coption to override the default one.
terminalizer-v2 configRECOMMENDED, use the
initcommand to create a global config file to be used instead of the default one.
terminalizer-v2 initFor Linux and MacOS, the created directory is located under the home directory ~/.terminalizer. For Windows, it is located under the AppData.
Recording
- command: Specify a command to be executed like- /bin/bash -l,- ls, or any other command. The default is- bashfor- Linuxor- powershell.exefor- Windows.
- cwd: Specify the current working directory path. The default is the current working directory path.
- env: Export additional ENV variables, to be read by your scripts when starting the recording.
- cols: Explicitly set the number of columns or use- autoto take the current number of columns of your shell.
- rows: Explicitly set the number of rows or use- autoto take the current number of rows of your shell.
Delays
- frameDelay: The delay between frames in ms. If the value is- autouse the actual recording delays.
- maxIdleTime: Maximum delay between frames in ms. Ignored if the- frameDelayisn't set to- auto. Set to- autoto prevent limiting the max idle time.
GIF
- quality: The quality of the generated GIF image (1 - 100).
- repeat: Amount of times to repeat GIF:- If value is -1, play once.
- If value is 0, loop indefinitely.
- If value is a positive number, loop ntimes.
 
- If value is 
Terminal
- cursorStyle: Cursor style can be one of- block,- underline, or- bar.
- fontFamily: You can use any font that is installed on your machine like- Monacoor- Lucida Console(CSS-like list).
- fontSize: The size of the font in pixels.
- lineHeight: The height of lines in pixels.
- letterSpacing: The spacing between letters in pixels.
Theme
You can set the colors of your terminal using one of the CSS formats:
- Hex: #FFFFFF.
- RGB: rgb(255, 255, 255).
- HSL: hsl(0, 0%, 100%).
- Name: white,red,blue.
You can use the value
transparenttoo.
The default colors that are assigned to the terminal colors are:
- background: transparent
- foreground: #afafaf
- cursor: #c7c7c7
- black: #232628
- red: #fc4384
- green: #b3e33b
- yellow: #ffa727
- blue: #75dff2
- magenta: #ae89fe
- cyan: #708387
- white: #d5d5d0
- brightBlack: #626566
- brightRed: #ff7fac
- brightGreen: #c8ed71
- brightYellow: #ebdf86
- brightBlue: #75dff2
- brightMagenta: #ae89fe
- brightCyan: #b1c6ca
- brightWhite: #f9f9f4
Watermark
You can add a watermark logo to your generated GIF images.
watermark:
  imagePath: AbsolutePathOrURL
  style:
    position: absolute
    right: 15px
    bottom: 15px
    width: 100px
    opacity: 0.9- watermark.imagePath: An absolute path for the image on your machine or a URL.
- watermark.style: Apply CSS styles (camelCase) to the watermark image, like resizing it.
Frame Box
terminalizer-v2 comes with predefined frames that you can use to make your GIF images look cool.
- frameBox.type: Can be- null,- window,- floating, or- solid.
- frameBox.title: To display a title for the frame or- null.
- frameBox.style: To apply custom CSS styles or to override the current ones.
Null Frame
No frame, just your recording.
Don't forget to add a
backgroundColorunderstyle.
frameBox:
  type: null
  title: null
  style:
    backgroundColor: blackWindow Frame
frameBox:
  type: window
  title: Terminalizer
  style: []Floating Frame
frameBox:
  type: floating
  title: Terminalizer
  style: []Solid Frame
frameBox:
  type: solid
  title: Terminalizer
  style: []Solid Frame Without Title
frameBox:
  type: solid
  title: null
  style: []Styling Hint
You can disable the default shadows and margins.
frameBox:
  type: solid
  title: null
  style:
    boxShadow: none
    margin: 0pxFAQ
How to support ZSH
The default command that gets recorded for Linux is bash -l. You need to change the default command to zsh.
- Generate a config file in the current directory
terminalizer-v2 config- Open the generated config file in your preferred editor.
- Change the commandtozsh:
command: zsh- You may need to change the font, check the font that is used in your terminal:
fontFamily: "Meslo for Powerline, Meslo LG M for Powerline"- Use the -coption to override the config file:
terminalizer-v2 record demo -c config.ymlIssues
error while loading shared libraries: libXss.so.1: cannot open shared object file: No such file or directory
Solution:
sudo yum install libXScrnSavererror while loading shared libraries: libgconf-2.so.4: cannot open shared object file: No such file or directory
Solution:
sudo apt-get install libgconf-2-4License
This project is under the MIT license.