# Terminalizer
[data:image/s3,"s3://crabby-images/17e04/17e04ca19b60b46167750514cf1c07e4dffe0958" alt="npm"](https://www.npmjs.com/package/terminalizer)
[data:image/s3,"s3://crabby-images/b3a66/b3a66cba14c9d067fa823a18b28f38a6285853c9" alt="npm"](https://github.com/faressoft/terminalizer/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/ea546/ea5462923565313e49a0a3584f2093757dea1591" alt="Gitter"](https://gitter.im/terminalizer/Lobby)
[data:image/s3,"s3://crabby-images/9e850/9e850edcc19bae482b5ebaa99dac9ba6af7b4f16" alt="Unicorn"](https://www.youtube.com/watch?v=QH2-TGUlwu4)
[data:image/s3,"s3://crabby-images/7e807/7e80791be81c6519a0fa9ba72f497ae18bfd58aa" alt="Tweet"](https://goo.gl/QJzJu1)
> Record your terminal and generate animated gif images or share a web player link [www.terminalizer.com](https://www.terminalizer.com)
data:image/s3,"s3://crabby-images/ca5e9/ca5e9a1e060908faba126c84109c6abe9f9beeb3" alt=""
Built to be jusT cOol 👌🦄 !
> If you think so, support me with a `star` and a `follow` 😘
---
data:image/s3,"s3://crabby-images/f62fe/f62fe976e483ca84f9e080376943c72131207424" alt=""
---
# Table of Contents
- [Terminalizer](#terminalizer)
- [Table of Contents](#table-of-contents)
- [Features](#features)
- [What's Next](#whats-next)
- [Installation](#installation)
- [Getting Started](#getting-started)
- [Compression](#compression)
- [Usage](#usage)
- [Init](#init)
- [Config](#config)
- [Record](#record)
- [Play](#play)
- [Render](#render)
- [Share](#share)
- [Generate](#generate)
- [Configurations](#configurations)
- [Recording](#recording)
- [Delays](#delays)
- [GIF](#gif)
- [Terminal](#terminal)
- [Theme](#theme)
- [Watermark](#watermark)
- [Frame Box](#frame-box)
- [Null Frame](#null-frame)
- [Window Frame](#window-frame)
- [Floating Frame](#floating-frame)
- [Solid Frame](#solid-frame)
- [Solid Frame Without Title](#solid-frame-without-title)
- [Styling Hint](#styling-hint)
- [FAQ](#faq)
- [How to support ZSH](#how-to-support-zsh)
- [Issues](#issues)
- [License](#license)
# Features
- Highly customizable.
- Cross platform (Linux, Windows, MacOS).
- Custom `window frames`.
- Custom `font`.
- Custom `colors`.
- Custom `styles` with `CSS`.
- 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 `Generate` command to generate a web player for a recording file.
- Support `apt-get`, `yum`, `brew` installation.
# Installation
You need to install [Node.js](https://nodejs.org/en/download/) first, then install the tool globally using this command:
```bash
npm install -g terminalizer
```
data:image/s3,"s3://crabby-images/7a230/7a230b859bb849a2c2f6685bc9414b2c99610b09" alt=""
> Still facing an issue? Check the [Issues](#issues) section or open a new issue.
The installation should be very smooth with Node.js v4-v16. 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](https://github.com/nodejs/node-gyp#installation).
# Getting Started
Start recording your terminal using the `record` command.
```bash
terminalizer record demo
```
A 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.
```bash
terminalizer play demo
```
Now let's render our recording as an animated gif.
```bash
terminalizer render demo
```
## Compression
GIF compression is not implemented yet. For now we recommend [https://gifcompressor.com](https://gifcompressor.com).
# Usage
> You can use the `--help` option to get more details about the commands and their options
```bash
terminalizer [options]
```
## Init
> Create a global config directory
```bash
terminalizer init
```
## Config
> Generate a config file in the current directory
```bash
terminalizer config
```
## Record
> Record your terminal and create a recording file
```bash
terminalizer record
```
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 record foo Start recording and create a recording file called foo.yml
terminalizer record foo --config config.yml Start recording with your own configurations
```
## Play
> Play a recording file on your terminal
```bash
terminalizer play
```
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
```bash
terminalizer render
```
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
```bash
terminalizer share
```
## Generate
> Generate a web player for a recording file
```bash
terminalizer generate
```
# 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 `-c` option to override the default one.
```bash
terminalizer config
```
> RECOMMENDED, use the `init` command to create a global config file to be used instead of the default one.
```bash
terminalizer init
```
For Linux and MacOS, the created directory is located under the home directory `~/config/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 `bash` for `Linux` or `powershell.exe` for `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 `auto` to take the current number of columns of your shell.
- `rows`: Explicitly set the number of rows or use `auto` to take the current number of rows of your shell.
## Delays
- `frameDelay`: The delay between frames in ms. If the value is `auto` use the actual recording delays.
- `maxIdleTime`: Maximum delay between frames in ms. Ignored if the `frameDelay` isn't set to `auto`. Set to `auto` to 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 `n` times.
## 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 `Monaco` or `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 `transparent` too.
The default colors that are assigned to the terminal colors are:
- background: data:image/s3,"s3://crabby-images/855f3/855f3aa6481bd4b5e9964e28c85c5ef7124b6606" alt="#ffffff" `transparent`
- foreground: data:image/s3,"s3://crabby-images/96a38/96a38d1378b5b55b36ff4fb40712097b1478e3c2" alt="#afafaf" `#afafaf`
- cursor: data:image/s3,"s3://crabby-images/dec7f/dec7f9d095bbcde7cc103bba3a351b1d30ced682" alt="#c7c7c7" `#c7c7c7`
- black: data:image/s3,"s3://crabby-images/ccff3/ccff38c9fc9338d7377eeaecb1c45e949fe1b335" alt="#232628" `#232628`
- red: data:image/s3,"s3://crabby-images/7f279/7f279afce7f77b4ff86c5a0d43ed66063ddf8c1e" alt="#fc4384" `#fc4384`
- green: data:image/s3,"s3://crabby-images/76cda/76cda718aef9ce5d30ba673b940ae1a58e7b612a" alt="#b3e33b" `#b3e33b`
- yellow: data:image/s3,"s3://crabby-images/6d238/6d23832f7a35b8b129bd80b16ec0e5a3613ea536" alt="#ffa727" `#ffa727`
- blue: data:image/s3,"s3://crabby-images/e5fce/e5fcef3179374103a1d91c7486ef9b368943114d" alt="#75dff2" `#75dff2`
- magenta: data:image/s3,"s3://crabby-images/362f2/362f2062fa3282ea94a3c498efa6786731e6dd1f" alt="#ae89fe" `#ae89fe`
- cyan: data:image/s3,"s3://crabby-images/3248c/3248c612845e944061d190dc5d27a51d98053333" alt="#708387" `#708387`
- white: data:image/s3,"s3://crabby-images/97d30/97d30fb02b7825b2898984554df5bcb96093d3ae" alt="#d5d5d0" `#d5d5d0`
- brightBlack: data:image/s3,"s3://crabby-images/873b3/873b32eb3ed42d29a25554a9e867d58e2a210e0f" alt="#626566" `#626566`
- brightRed: data:image/s3,"s3://crabby-images/a7106/a710634488600442980010817e59a8d7b6d6c2d6" alt="#ff7fac" `#ff7fac`
- brightGreen: data:image/s3,"s3://crabby-images/d1a0a/d1a0a9b6e3138e15f21d4105f74e4896b923ce28" alt="#c8ed71" `#c8ed71`
- brightYellow: data:image/s3,"s3://crabby-images/fa7ab/fa7abbf49f3e792a96f163b444f2b06a807aea82" alt="#ebdf86" `#ebdf86`
- brightBlue: data:image/s3,"s3://crabby-images/e5fce/e5fcef3179374103a1d91c7486ef9b368943114d" alt="#75dff2" `#75dff2`
- brightMagenta: data:image/s3,"s3://crabby-images/362f2/362f2062fa3282ea94a3c498efa6786731e6dd1f" alt="#ae89fe" `#ae89fe`
- brightCyan: data:image/s3,"s3://crabby-images/7a212/7a212b23cf6abe41d86b18278c4d163e3e83ed2e" alt="#b1c6ca" `#b1c6ca`
- brightWhite: data:image/s3,"s3://crabby-images/8ff3f/8ff3f11d4a1cd78bf1cc5d58c06d5673fbdeb43a" alt="#f9f9f4" `#f9f9f4`
## Watermark
You can add a watermark logo to your generated GIF images.
data:image/s3,"s3://crabby-images/ca836/ca836d594b58aa60ec0df2312625c8f45dede6d3" alt=""
```
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 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.
data:image/s3,"s3://crabby-images/58b54/58b54ff279bbe43e2462b97244766317d1ffa677" alt=""
> Don't forget to add a `backgroundColor` under `style`.
```
frameBox:
type: null
title: null
style:
backgroundColor: black
```
### Window Frame
data:image/s3,"s3://crabby-images/e4fa4/e4fa4178c4672bab79be556ea6270a72ebd95a52" alt=""
```
frameBox:
type: window
title: Terminalizer
style: []
```
### Floating Frame
data:image/s3,"s3://crabby-images/b3abd/b3abd6376513cb55e0e7355d1fc29a99fcd7b157" alt=""
```
frameBox:
type: floating
title: Terminalizer
style: []
```
### Solid Frame
data:image/s3,"s3://crabby-images/710d5/710d5702e6520b41cbd2dcc131462f38aaff8ce8" alt=""
```
frameBox:
type: solid
title: Terminalizer
style: []
```
### Solid Frame Without Title
data:image/s3,"s3://crabby-images/f4079/f4079513fcff4f95c5bb8064be37abb2b05a7f65" alt=""
```
frameBox:
type: solid
title: null
style: []
```
### Styling Hint
You can disable the default shadows and margins.
data:image/s3,"s3://crabby-images/e2efa/e2efaff8163657ff5f5c096ffaa8da4355dd56f8" alt=""
```
frameBox:
type: solid
title: null
style:
boxShadow: none
margin: 0px
```
# FAQ
### 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
```bash
terminalizer config
```
- Open the generated config file in your preferred editor.
- Change the `command` to `zsh`:
```
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 `-c` option to override the config file:
```bash
terminalizer record demo -c config.yml
```
# Issues
> error while loading shared libraries: libXss.so.1: cannot open shared object file: No such file or directory
Solution:
```bash
sudo yum install libXScrnSaver
```
> error while loading shared libraries: libgconf-2.so.4: cannot open shared object file: No such file or directory
Solution:
```bash
sudo apt-get install libgconf-2-4
```
> Error: EACCES: permission denied, access '/usr/local/lib'
Solution:
```bash
sudo mkdir -p /usr/local/lib/node_modules && sudo chown -R $(whoami):$(whoami) /usr/local/lib/node_modules
# then use the install command in the "Installation" section above
npm install -g terminalizer
```
# License
This project is under the MIT license.