Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vuongxuongminh/yii2-console-menu
Support build pretty menu for Yii2 console controllers.
https://github.com/vuongxuongminh/yii2-console-menu
console-menu yii2 yii2-console yii2-console-menu yii2-extension
Last synced: 2 months ago
JSON representation
Support build pretty menu for Yii2 console controllers.
- Host: GitHub
- URL: https://github.com/vuongxuongminh/yii2-console-menu
- Owner: vuongxuongminh
- License: bsd-3-clause
- Created: 2019-04-10T09:54:55.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-04-16T17:10:07.000Z (over 5 years ago)
- Last Synced: 2024-05-02T23:08:06.474Z (8 months ago)
- Topics: console-menu, yii2, yii2-console, yii2-console-menu, yii2-extension
- Language: PHP
- Homepage:
- Size: 28.3 KB
- Stars: 8
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Yii2 Console Menu
[![Latest Stable Version](https://poser.pugx.org/vxm/yii2-console-menu/v/stable)](https://packagist.org/packages/vxm/yii2-console-menu)
[![Total Downloads](https://poser.pugx.org/vxm/yii2-console-menu/downloads)](https://packagist.org/packages/vxm/yii2-console-menu)
[![Build Status](https://travis-ci.org/vuongxuongminh/yii2-console-menu.svg?branch=master)](https://travis-ci.org/vuongxuongminh/yii2-console-menu)
[![Code Coverage](https://scrutinizer-ci.com/g/vuongxuongminh/yii2-console-menu/badges/coverage.png?b=master)](https://scrutinizer-ci.com/g/vuongxuongminh/yii2-console-menu/?branch=master)
[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/vuongxuongminh/yii2-console-menu/badges/quality-score.png?b=master)](https://scrutinizer-ci.com/g/vuongxuongminh/yii2-console-menu/?branch=master)
[![Yii2](https://img.shields.io/badge/Powered_by-Yii_Framework-green.svg?style=flat)](http://www.yiiframework.com/)## About it
An extension support build pretty menu base on [nunomaduro/laravel-console-menu](https://github.com/nunomaduro/laravel-console-menu), and is a [php-school/cli-menu](https://github.com/php-school/cli-menu) wrapper for Yii2 console controller.
## Requirements
* [PHP >= 7.1](http://php.net)
* [yiisoft/yii2 >= 2.0.13](https://github.com/yiisoft/yii2)## Installation
Require Yii2 console menu using [Composer](https://getcomposer.org):
```bash
composer require vxm/yii2-console-menu
```## Usage
### Quick Setup
```php
use yii\console\Controller;
/**
* @method \vxm\consoleMenu\Menu menu(string $title = '', array $options = [])
*/
class TestController extends Controller
{
/**
* Execute the action.
*
* @return void
*/
public function actionTest()
{
$option = $this->menu('Pizza menu', [
'Freshly baked muffins',
'Freshly baked croissants',
'Turnovers, crumb cake, cinnamon buns, scones',
])->open();$this->stdout("You have chosen the option number #$option");
}
}
```### Setup with a question
```php
use yii\console\Controller;
/**
* @method \vxm\consoleMenu\Menu menu(string $title = '', array $options = [])
*/
class TestController extends Controller
{
/**
* Execute the action.
*
* @return void
*/
public function actionTest()
{
$option = $this->menu('Pizza menu')
->addOption('mozzarella', 'Mozzarella')
->addOption('chicken_parm', 'Chicken Parm')
->addOption('sausage', 'Sausage')
->addQuestion('Make your own', 'Describe your pizza...')
->addOption('burger', 'Prefer burgers')
->setWidth(80)
->open();
$this->stdout("You have chosen the text option: $option");
}
}
```### Setup with advanced option, in this case, a password
```php
use yii\console\Controller;
/**
* @method \vxm\consoleMenu\Menu menu(string $title = '', array $options = [])
*/
class TestController extends Controller
{
/**
* Execute the action.
*
* @return void
*/
public function actionTest()
{
$menu = $this->menu('Pizza menu')
->addOption('mozzarella', 'Mozzarella')
->addOption('chicken_parm', 'Chicken Parm')
->addOption('sausage', 'Sausage')
->addQuestion('Make your own', 'Describe your pizza...');
$itemCallable = function (\PhpSchool\CliMenu\CliMenu $cliMenu) use ($menu) {
$cliMenu->askPassword()
->setValidator(function ($password) {
return $password === 'secret';
})
->setPromptText('Secret password?')
->ask();$menu->setResult('Free spice!');
$cliMenu->close();
};
$menu->addItem('Add extra spice for free (password needed)', $itemCallable);$option = $menu->addOption('burger', 'Prefer burgers')
->setWidth(80)
->open();$this->stdout("You have chosen the text option: $option");
}
}
```### Appearance
Available colors: `black`, `red`, `green`, `yellow`, `blue`, `magenta`, `cyan`, `white`.
```php
$this->menu($title, $options)
->setForegroundColour('green')
->setBackgroundColour('black')
->setWidth(200)
->setPadding(10)
->setMargin(5)
->setExitButtonText("Abort") // remove exit button with ->disableDefaultItems()
->setUnselectedMarker('❅')
->setSelectedMarker('✏')
->setTitleSeparator('*-')
->addLineBreak('<3', 2)
->addStaticItem('AREA 2')
->open();
```Check out the full documentation [here](https://github.com/php-school/cli-menu/blob/master/README.md).