OA 的終端機進度工具 🚀
終端機上使用 Node.js「進度工具」
npm install @oawu/cli-progress
引入 require('@oawu/cli-progress')
即可使用,如下範例:
const Progress = require('@oawu/cli-progress')
Progress.title('標題', '副標題')
Progress.total(3)
setTimeout(_ => {
Progress.advance
setTimeout(_ => {
Progress.advance
setTimeout(_ => {
Progress.done()
}, 1000)
}, 1000)
}, 1000)
-
使用色彩器(@oawu/xterm),於一開始使用
Progress.option.color = true
即可,預設為false
-
設定左邊空格基礎
Progress.option.space = 2
,預設為3
-
設定讀取中
- 顯示:於一開始使用
Progress.option.loading = "⠦⠧⠇⠏⠉⠙⠹⠸⠼⠴⠤⠦"
,預設為⠦⠧⠇⠏⠉⠙⠹⠸⠼⠴⠤⠦
- 顏色:於一開始使用
Progress.option.loading.color = Xterm.red
,預設為Xterm.yellow
- 顯示:於一開始使用
-
設定主標題顏色,於一開始使用
Progress.option.title.color = Xterm.red
,預設為Xterm.gray
-
設定小標題顏色,於一開始使用
Progress.option.subtitle.color = Xterm.red
,預設為Xterm.gray
-
設定百分比顏色,於一開始使用
Progress.option.percent.color = Xterm.red
,預設為Xterm.gray
-
設定數值顏色,於一開始使用
Progress.option.index.color = Xterm.red
,預設為Xterm.dim
-
設定 done 顏色,於一開始使用
Progress.option.done.color = Xterm.red
,預設為Xterm.green
-
設定 fail 顏色,於一開始使用
Progress.option.fail.color = Xterm.red
,預設為Xterm.red
-
設定主標題符號
- 顯示:於一開始使用
Progress.option.header = "!"
,預設為◉
- 顏色:於一開始使用
Progress.option.header.color = Xterm.red
,預設為Xterm.purple
- 顯示:於一開始使用
-
設定小標題符號
- 顯示:於一開始使用
Progress.option.newline = "!"
,預設為↳
- 顏色:於一開始使用
Progress.option.newline.color = Xterm.red
,預設為Xterm.dim.purple
- 顯示:於一開始使用
-
設定分隔符號
- 顯示:於一開始使用
Progress.option.dash = "!"
,預設為─
- 顏色:於一開始使用
Progress.option.dash.color = Xterm.red
,預設為Xterm.dim
- 顯示:於一開始使用
-
設定點點點符號
- 顯示:於一開始使用
Progress.option.dot = "!"
,預設為…
- 顏色:於一開始使用
Progress.option.dot.color = Xterm.red
,預設為Xterm.dim.lightBlack
- 顯示:於一開始使用
以下為基本設定範例與執行結果:
const Progress = require('@oawu/cli-progress')
Progress.option.color = true // 使用顏色
Progress.option.done.color = text => Xterm.lightBlue(text).dim() // done 時顯示為細體藍色
Progress.option.fail.color = Xterm.red // fail 時為紅色
Progress.option.header = '➜' // 主標題符號改為 `➜`
Progress.option.header.color = Xterm.lightGray // 主標題符號顏色改為亮灰色
// 開始執行
Progress.title('標題', '副標題')
Progress.total(3)
setTimeout(_ => {
Progress.advance
setTimeout(_ => {
Progress.advance
setTimeout(_ => {
Progress.done()
}, 1000)
}, 1000)
}, 1000)
執行中:
完成: