- Vue 3 + TypeScript + Element Plus 前端界面 - Pinia 状态管理 - Vue Router 4 路由管理 - Axios HTTP 客户端 - MSW (Mock Service Worker) 开发环境模拟 - 账户管理界面 (列表、详情、三科目余额展示) - 交易管理界面 (列表、详情) - 对账管理界面 (三账校验) - 完善的 API 客户端封装 - Docker 容器化配置 - Nginx 配置用于生产环境
22 lines
866 B
JavaScript
22 lines
866 B
JavaScript
const ESC = '\u001B[';
|
|
/** Move cursor to first column */
|
|
export const cursorLeft = ESC + 'G';
|
|
/** Hide the cursor */
|
|
export const cursorHide = ESC + '?25l';
|
|
/** Show the cursor */
|
|
export const cursorShow = ESC + '?25h';
|
|
/** Move cursor up by count rows */
|
|
export const cursorUp = (rows = 1) => (rows > 0 ? `${ESC}${rows}A` : '');
|
|
/** Move cursor down by count rows */
|
|
export const cursorDown = (rows = 1) => rows > 0 ? `${ESC}${rows}B` : '';
|
|
/** Move cursor to position (x, y) */
|
|
export const cursorTo = (x, y) => {
|
|
if (typeof y === 'number' && !Number.isNaN(y)) {
|
|
return `${ESC}${y + 1};${x + 1}H`;
|
|
}
|
|
return `${ESC}${x + 1}G`;
|
|
};
|
|
const eraseLine = ESC + '2K';
|
|
/** Erase the specified number of lines above the cursor */
|
|
export const eraseLines = (lines) => lines > 0 ? (eraseLine + cursorUp(1)).repeat(lines - 1) + eraseLine + cursorLeft : '';
|