定制 sugarcraft/sugar-readline 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

sugarcraft/sugar-readline

最新稳定版本:v0.2.0

Composer 安装命令:

composer require sugarcraft/sugar-readline

包简介

PHP port of erikgeiser/promptkit — interactive line-editing prompt library. Supports text input with validation/completion/hidden-password mode, selection prompts with filtering/pagination/cursor navigation, confirmation prompts, and textarea multi-line input.

README 文档

README

sugar-readline

CI codecov Packagist Version License PHP

SugarReadline

PHP port of erikgeiser/promptkit — interactive line-editing prompt library for terminal UIs.

Features

  • TextPrompt — single-line input with validation, auto-completion, hidden/password mode, char limit, default value
  • SelectionPrompt — filtered list with cursor navigation and pagination
  • MultiSelectPrompt — filtered multi-choice with min/max enforcement and FIFO rollover at the cap
  • ConfirmationPrompt — yes/no with customizable labels, decoupled select-vs-submit
  • TextareaPrompt — multi-line text input with line/column cursor and optional max-line cap
  • Pure renderer — every method returns a new immutable instance; view() returns ANSI strings, value() returns the data

Install

composer require sugarcraft/sugar-readline

Quick Start

Text Prompt

use SugarCraft\Readline\{Key, TextPrompt};

$p = TextPrompt::new('Enter your name: ')
    ->withDefault('Anonymous')
    ->withCompletions(['Alice', 'Bob', 'Carol']);

$p = $p->handleChar('A')->handleChar('l')->handleKey(Key::Tab)->submit();
echo $p->value();  // 'Alice'

Selection Prompt

use SugarCraft\Readline\SelectionPrompt;

$p = SelectionPrompt::new('Choose a fruit:', ['Apple', 'Banana', 'Cherry', 'Date'])
    ->withFilter('an');                 // Banana matches
echo $p->selectedValue();              // 'Banana'

Multi-Select Prompt

use SugarCraft\Readline\{Key, MultiSelectPrompt};

$p = MultiSelectPrompt::new('Pick:', ['A', 'B', 'C'])
    ->withMinSelections(1)
    ->handleKey(Key::Space)              // mark A
    ->handleKey(Key::Down)
    ->handleKey(Key::Space)              // mark B
    ->handleKey(Key::Enter);             // submit (min satisfied)

print_r($p->selectedValues());          // ['A', 'B']

Confirmation Prompt

use SugarCraft\Readline\{ConfirmationPrompt, Key};

$p = ConfirmationPrompt::new('Delete file?')
    ->handleKey('n')                     // selects No (does not auto-submit)
    ->handleKey(Key::Left)               // changes mind back to Yes
    ->submit();
echo $p->result() ? 'yes' : 'no';       // 'yes'

Key Bindings

The SugarCraft\Readline\Key class exposes symbolic constants for every supported key.

  • Key::Left / Key::Right — move cursor (text input)
  • Key::Up / Key::Down — navigate selection list / change line in textarea
  • Key::PageUp / Key::PageDown — page through long lists
  • Key::Home / Key::End — jump within the current line / list
  • Key::Enter — submit text or select current choice
  • Key::Space — toggle mark in multi-select
  • Key::Tab — auto-complete or toggle confirmation value
  • Key::Backspace / Key::Delete — delete characters
  • Key::CtrlU / Key::CtrlK — delete to start / end of line
  • Key::Escape / Key::CtrlC — abort

Submit / Abort Semantics

Each prompt is a state machine with three states: pending, submitted, aborted.

  • submit() finalises the prompt; for MultiSelectPrompt it only succeeds when canSubmit() is true.
  • abort() (or feeding Key::Escape / Key::CtrlC) discards the prompt; value() / selectedValues() then return empty.
  • isSubmitted() / isAborted() report status; currentValue() (Confirmation) and selectedValue() (Selection) reflect the current cursor regardless of submission state.

License

MIT

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 9
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-05-07

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固