本文整理匯總了TypeScript中terminal-kit.terminal.hideCursor方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript terminal.hideCursor方法的具體用法?TypeScript terminal.hideCursor怎麽用?TypeScript terminal.hideCursor使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類terminal-kit.terminal
的用法示例。
在下文中一共展示了terminal.hideCursor方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: handleKeyEvent
async function handleKeyEvent(name: string,
currentIndex: number,
projects: ProjectInfo[],
callback: (projectId: string) => void): Promise<number> {
switch (name) {
case 'DOWN': {
currentIndex = (currentIndex + 1) % projects.length
rerender(projects, currentIndex)
break
}
case 'UP': {
currentIndex = (currentIndex + projects.length - 1) % projects.length
rerender(projects, currentIndex)
break
}
case 'ENTER': {
clear(projects)
terminal.hideCursor(false)
terminal.grabInput(false)
callback(projects[currentIndex].projectId)
break
}
case 'CTRL_C': {
clear(projects)
terminal.hideCursor(false)
terminal.grabInput(false)
process.exit()
}
default: {
break
}
}
return currentIndex
}
示例2: handleKeyEvent
async function handleKeyEvent(name: string,
currentIndex: number,
selectedIndices: number[],
projects: ProjectInfo[],
env: SystemEnvironment,
callback: () => void): Promise<number> {
switch (name) {
case 'DOWN': {
currentIndex = (currentIndex + 1) % projects.length
rerender(projects, currentIndex, selectedIndices)
break
}
case 'UP': {
currentIndex = (currentIndex + projects.length - 1) % projects.length
rerender(projects, currentIndex, selectedIndices)
break
}
case ' ': { // SPACE
const index = selectedIndices.indexOf(currentIndex)
if (index >= 0) {
selectedIndices.splice(index, 1)
} else {
selectedIndices.push(currentIndex)
}
rerender(projects, currentIndex, selectedIndices)
break
}
case 'ENTER': {
await handleSelect(selectedIndices, projects, env)
terminal.grabInput(false)
callback()
break
}
case 'CTRL_C': {
clear(projects)
terminal.hideCursor(false)
terminal.grabInput(false)
process.exit()
}
default: {
break
}
}
return currentIndex
}
示例3: async
export default async (props: DeleteProps, env: SystemEnvironment): Promise<void> => {
const {resolver, out} = env
if (props.sourceProjectId) {
out.startSpinner(deletingProjectMessage(props.sourceProjectId))
try {
await deleteProject([props.sourceProjectId], resolver)
out.stopSpinner()
out.write(deletedProjectMessage([props.sourceProjectId]))
} catch (e) {
out.stopSpinner()
if (e.errors) {
const errors = parseErrors(e)
const output = generateErrorOutput(errors)
out.writeError(`${output}`)
} else {
throw e
}
}
} else {
const projects = await fetchProjects(resolver)
terminal.saveCursor()
terminal.grabInput()
terminal.hideCursor()
terminal(`\n`)
// initially select current project
const projectId = getProjectId(env)
let currentIndex = projectId ? projects.map(p => p.projectId).indexOf(projectId) : 0
const selectedIndices = []
render(projects, currentIndex, selectedIndices)
await new Promise(resolve => {
terminal.on('key', async (name: string) => {
currentIndex = await handleKeyEvent(name, currentIndex, selectedIndices, projects, env, resolve)
})
})
}
}
示例4: interactiveProjectSelection
async function interactiveProjectSelection(env: SystemEnvironment): Promise<string> {
const projects = await fetchProjects(env.resolver)
terminal.saveCursor()
terminal.grabInput()
terminal.hideCursor()
terminal(`\n`)
let currentIndex = 0
render(projects, currentIndex)
const projectId = await new Promise<string>(resolve => {
terminal.on('key', async (name: string) => {
currentIndex = await handleKeyEvent(name, currentIndex, projects, resolve)
})
})
return projectId
}
示例5: handleSelect
async function handleSelect(selectedIndices: number[], projects: ProjectInfo[], env: SystemEnvironment): Promise<void> {
terminal(`\n\n${deletingProjectWarningMessage}`)
terminal.grabInput(true)
await new Promise(resolve => {
terminal.on('key', function (name) {
if (name !== 'y') {
process.exit(0)
}
terminal.grabInput(false)
resolve()
})
})
const projectIdsToDelete = selectedIndices.reduce((prev: string[], current: number) => {
prev.push(projects[current].projectId)
return prev
}, [])
terminal.restoreCursor()
terminal.eraseDisplayBelow()
terminal.hideCursor(false)
env.out.startSpinner(deletingProjectsMessage(projectIdsToDelete))
try {
await deleteProject(projectIdsToDelete, env.resolver)
env.out.stopSpinner()
env.out.write(deletedProjectMessage(projectIdsToDelete))
} catch (e) {
env.out.stopSpinner()
if (e.errors) {
const errors = parseErrors(e)
const output = generateErrorOutput(errors)
env.out.writeError(`${output}`)
} else {
throw e
}
}
}