macocci7/file-selector-prompt

An Additional File Selector Prompt for your Laravel/Prompts Applications.

v0.1.2 2024-08-21 01:04 UTC

This package is auto-updated.

Last update: 2024-10-21 02:02:53 UTC


README

An Additional File Selector Prompt for your Laravel/Prompts Application.

Feature

File Selector Prompt provides assistance in entering file paths quickly and accurately in interactive mode.

2024-05-29.00-13-46.mp4

By using fileselector(), you can input the file path quickly and accurately.

Installation

composer require macocci7/file-selector-prompt

Available Functions

File-selector

The fileselector function can be used to provide auto-completion for possible choices.

This function lists the entries in the directory on the local file system that matches the input, as the options for suggest.

The user can still provide any answer, regardless of the auto-completion hints:

use function Macocci7\FileSelectorPrompt\fileselector;

$path = fileselector('Select a file to import.');

You may also include placeholder text, a default value, a required value, and an informational hint:

$path = fileselector(
    label: 'Select a file to import.',
    placeholder: 'E.g. ./vendor/autoload.php',
    default: '',
    required: 'The file path is required.',
    hint: 'Input the file path.',
);

If you would like to perform additional validation logic, you may pass a closure to the validate argument:

$path = fileselector(
    label: 'Select a file to import.',
    placeholder: 'E.g. ./vendor/autoload.php',
    hint: 'Input the file path.',
    validate: fn (string $value) => match (true) {
        !is_readable($value) => 'Cannot read the file.',
        default => null,
    },
);

Additionally, you may make changes to the input before it gets validated by passing a closure to the transform argument.

$path = fileselector(
    label: 'Select a file to import.',
    placeholder: 'E.g. ./vendor/autoload.php',
    hint: 'Input the file path.',
    validate: fn (string $value) => match (true) {
        !is_readable($value) => 'Cannot read the file.',
        default => null,
    },
    transform: fn ($value) => realpath($value),
);

Finally, if you would like to filter the files listed in the choices with the file extensions, you may pass an array to the extensions argument:

$path = fileselector(
    label: 'Select a file to import.',
    placeholder: 'E.g. ./vendor/autoload.php',
    hint: 'Input the file path.',
    validate: fn (string $value) => match (true) {
        !is_readable($value) => 'Cannot read the file.',
        default => null,
    },
    extensions: [
        '.json',
        '.php',
    ],
);

Form

Macocci7\FileSelectorPrompt\form function wraps Laravel\Prompt\form and supports fileselector.

use function Macocci7\FileSelectorPrompt\form;

$responses = form()
    ->fileselector(
        label: 'Select a file to import.',
        placeholder: 'E.g. ./vendor/autoload.php',
        hint: 'Input the file path.',
        validate: fn (string $value) => match (true) {
            !is_readable($value) => 'Cannot read the file.',
            default => null,
        },
        extensions: [
            '.json',
            '.php',
        ],
    )->submit();

License

MIT license