本文整理匯總了TypeScript中terminal-kit.terminal類的典型用法代碼示例。如果您正苦於以下問題:TypeScript terminal類的具體用法?TypeScript terminal怎麽用?TypeScript terminal使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了terminal類的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: function
terminal.on('key', function (name) {
if (name !== 'y') {
process.exit(0)
}
terminal.grabInput(false)
resolve()
})
示例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: Promise
await new Promise(resolve => {
terminal.on('key', function (name) {
if (name !== 'y') {
process.exit(0)
}
terminal.grabInput(false)
resolve()
})
})
示例5: 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
}
示例6: 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
}
}
}
示例7: 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
}
示例8: question
(error: any, result: any) => {
if (result) {
term.green("'Yes' detected! Good bye!\n");
} else {
term.red("'No' detected, are you sure?\n");
question();
}
}
示例9:
() => {
const input = term.inputField({
history: history1,
autoComplete: autoComplete1,
autoCompleteMenu: true
}).promise;
term.green("\nYour name is '%s'\n", input);
};