- Vue 3 + TypeScript + Element Plus 前端界面 - Pinia 状态管理 - Vue Router 4 路由管理 - Axios HTTP 客户端 - MSW (Mock Service Worker) 开发环境模拟 - 账户管理界面 (列表、详情、三科目余额展示) - 交易管理界面 (列表、详情) - 对账管理界面 (三账校验) - 完善的 API 客户端封装 - Docker 容器化配置 - Nginx 配置用于生产环境
46 lines
896 B
JavaScript
46 lines
896 B
JavaScript
var splitRE = /\r?\n/g
|
|
var emptyRE = /^\s*$/
|
|
var needFixRE = /^(\r?\n)*[\t\s]/
|
|
|
|
module.exports = function deindent (str) {
|
|
if (!needFixRE.test(str)) {
|
|
return str
|
|
}
|
|
var lines = str.split(splitRE)
|
|
var min = Infinity
|
|
var type, cur, c
|
|
for (var i = 0; i < lines.length; i++) {
|
|
var line = lines[i]
|
|
if (!emptyRE.test(line)) {
|
|
if (!type) {
|
|
c = line.charAt(0)
|
|
if (c === ' ' || c === '\t') {
|
|
type = c
|
|
cur = count(line, type)
|
|
if (cur < min) {
|
|
min = cur
|
|
}
|
|
} else {
|
|
return str
|
|
}
|
|
} else {
|
|
cur = count(line, type)
|
|
if (cur < min) {
|
|
min = cur
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return lines.map(function (line) {
|
|
return line.slice(min)
|
|
}).join('\n')
|
|
}
|
|
|
|
function count (line, type) {
|
|
var i = 0
|
|
while (line.charAt(i) === type) {
|
|
i++
|
|
}
|
|
return i
|
|
}
|