1.0.2 • Published 3 years ago

@fed123/cli-base v1.0.2

Weekly downloads
-
License
BSD-3-Clause
Repository
-
Last release
3 years ago

CLI BASE TOOLS

Node Cli 基础方法库

Getting Started

  • $ npm install @fed123/cli-base --save
import { consts, utils, files } from '@fed123/cli-base';
const { print } = utils;

print('debug', 'hello', 'world');

API

1. consts 静态常量

属性名描述类型
HOMEPATH用户 home 目录string
IS_WIN是否是 windows 系统boolean

2. utils 一些常用的方法

方法名描述参数定义返回值
progressBar返回一个进度条 stringrecent: number, total?: number, label?: stringstring
print带颜色级别的 console.logtype: 'debug'|'info'|'success'|'warn'|'error', ...msgs: BaseType[](filepath: string) => any
printJSON打印单层的 JSONjson: Record<string, BaseType>void
parseProperties解析 .properties 文件,返回一个 JSONfile: stringPromise<Record<string, any>>
templateRender最简单的模板渲染tpl: string, data: Record<string, any> = {}string
confirmnode 控制台二次确认message: string, defaultValue = falsePromise<boolean>
selectnode 控制台用户选择message: string, options: SelectOptions[] | string[], defaultValue: string | numberPromise<string>
inputnode 控制台用户输入message: string, defaultValue?: string, validator = (v: string) => anyPromise<string>
passwordnode 控制台密码输入message: string, defaultValue?: string, validator = (v: string) => anyPromise<string>
holdingnode 控制台进入等待状态,按回车继续tips = '按回车继续...'Promise<boolean>
exec执行 shell 命令,返回执行结果command: string, cwd = process.cwd()Promise<any>
execSync同步执行 shell 命令command: string, cwd = process.cwd()SpawnSyncReturns

其中 inputpassword 方法的第 3 个参数是校验方法,入参是输入的值,如果返回 false 或 Error(支持 Promise),则表示校验失败,例如:

utils.input('请输入用户名', null, async (value) => {
  // 直接校验
  return value === 'zhangsan'; 

  // 返回自定义错误文案
  return value === 'zhangsan' ? true : new Error('校验失败!');

  // 远程校验
  return await request(`api/validate?name=${value}`);
});

扩展的类型定义

/**
 * 基本类型,不算 object、null、undefined
 */
export type BaseType = string | number | boolean | symbol;

3. files 文件操作相关的常用方法

方法名描述参数定义返回值
fileIterator遍历目录文件,执行 callback见下文Promise<any>
dirSyncIterator遍历目录文件,同步到目标目录,并对每一个文件执行 callback见下文Promise<any>
getFileCount统计目录中的文件数量src: string, exclude?: RegExpPromise<number>
copyDir逐个复制目录中的文件options: OptionShapePromise<any>
clearDir清空目录(有二次确认)options: ClearOptionsPromise<boolean>
findInFolder从目录中查找内容符合条件的文件src: string, callback: (filePath: string, content: string) => boolean, options: SearchOptionsPromise<SearchResult[]

扩展的类型定义

// 遍历文件目录,执行 callback
export async function fileIterator(
  /** 目录路径 */
  src: string,
  /** 执行到文件时的回调,如果返回 false 或 async false,则遍历中止 */
  fileCallback: (filePath: string, fileRelativePath: string) => any,
  /** 执行到目录时的回调 */
  dirCallback?: (dirRelativePath: string) => any,
  /** 忽略的文件 */
): Promise<any>;

// 遍历文件目录,同步到目标目录,并对每一个文件执行 callback
export async function dirSyncIterator(
  /** 源文件目录 */
  source: string,
  /** 目标目录 */
  target: string,
  /** 执行到文件时的回调 */
  callback: (sourceFile: string, targetFile: string) => any,
  /** 忽略的文件 */
  exclude?: RegExp
): Promise<any>

// copyDir 方法的参数
export interface OptionShape {
  /** 文件来源目录 */
  src: string;
  /** 目标目录 */
  dist: string;
  /** 文件内容替换规则  */
  replacer?: { holder: RegExp; value: string }[];
  /** 忽略的文件 */
  exclude?: RegExp;
  /** 只读文件(不读取&替换的文件) */
  readonlyFile?: RegExp;
  /** 文件名替换方法 */
  fileNameTransfer?: (name: string) => string;
  /** 文件内容格式化方法 */
  contentFormatter?: (content: string, src: string) => Promise<string>;
}

// clearDir 方法的参数 
export interface ClearOptions {
  /** 要清除的目录 */
  src: string;
  /** 是否有二次确认 */
  confirm?: boolean;
  /** 二次确认文案 */
  confirmText?: string;
  /** 忽略的文件 */
  exclude?: RegExp;
}

// findInFolder 方法的参数
export interface SearchOptions {
  /** 是否找到所有文件,默认 false,即找到第 1 个就返回 */
  all?: boolean;
  /** 如果指定了 include,则只处理匹配的文件 */
  include?: RegExp;
  /** 匹配规则的文件跳过 */
  exclude?: RegExp;
  /** 文件大小限制(byte),超过大小的文件不遍历 */
  limit?: number;
  /** 读取文件的编码,默认是 utf-8 */
  encoding?: BufferEncoding;
}

export interface SearchResult {
  filePath: string;
  fileRelativePath: string;
  fileSize: number;
}

CHANGELOG

  • 1.0.0 发布 1.0 版本,整合并优化 已有能力
  • 1.0.4 优化文档,迁移代码仓库
  • 1.1.0 去掉 BaseAction ,简化架构
  • 1.1.7 增强 print 方法,可以将日志输出到本地

LICENSE

BSD-3-Clause License

Contact Us

ch19900606@gmail.com