awcodes / hydro
This is a command-line tool that replaces the need to use Filament's Plugin Skeleton through GitHub by allowing local setup of your plugin from the start.
Installs: 18
Dependents: 0
Suggesters: 0
Security: 0
Stars: 9
Watchers: 2
Forks: 0
Open Issues: 3
Type:project
Requires
- php: ^8.1
- ext-intl: *
- ext-posix: *
- nunomaduro/termwind: ^1.15
Requires (Dev)
- laravel-zero/framework: ^10.0
- laravel/pint: ^1.5
- mockery/mockery: ^1.5.1
- pestphp/pest: ^1.22.3
This package is auto-updated.
Last update: 2025-01-09 21:32:18 UTC
README
A Hydro CLI Tool.
This is a command-line tool that replaces the need to use Filament's Plugin Skeleton through GitHub by allowing local setup of your plugin from the start.
Requirements
- PHP 8.0+
Installation
composer global require awcodes/hydro
Upgrading
composer global update awcodes/hydro
Usage
Make sure ~/.composer/vendor/bin
is in your terminal's path.
cd ~/<working-directory> hydro new AwesomePlugin
Customizing Hydro
While the default actions Hydro provides are great, most users will want to customize at least a few of the steps. Thankfully, Hydro is built to be customized!
There are three ways to customize your usage of Hydro: command-line arguments or a config file.
Most users will want to set their preferred configuration options once and then never think about it again. That's best solved by creating a config file.
But if you find yourself needing to change the way you interact with Hydro on a project-by-project basis, you may also want to use the command-line parameters to customize Hydro when you're using it.
Creating a config file
You can create a config file at ~/.hydro/config
rather than pass the same
arguments each time you create a new project.
The following command creates the file, if it doesn't exist, and edits it:
hydro edit-config
The config file contains the configuration parameters you can customize, and will be read on every usage of Hydro.
Using command-line parameters
Any command-line parameters passed in will override Hydro's defaults and your config settings. See a full list of the parameters you can pass in.
Hydro Commands
help
orhelp-screen
show the help screen
-
edit-config
edits your config file (and creates one if it doesn't exist)hydro edit-config
Configurable parameters
You can optionally pass one or more of these parameters every time you use Hydro. If you find yourself wanting to configure any of these settings every time you run Hydro, that's a perfect use for the config files.
-
-e
or--editor
to define your editor command. Whatever is passed here will be run as$EDITOR .
after creating the project.# runs "code ." in the project directory after creating the project hydro new AwesomePlugin --editor=code
-
-p
or--path
to specify where to install the application.hydro new AwesomePlugin --path=~/Sites
-
-m
or--message
to set the first Git commit message.hydro new AwesomePlugin --message="This filament plugin runs fast!"
-
-f
or--force
to force install even if the directory already exists# Creates a new scaffolding after deleting ~/Sites/awesome-plugin hydro new AwesomePlugin --force
GitHub Repository Creation
Important: To create new repositories Hydro requires one of the following tools to be installed:
- the official GitHub command line tool
- the hub command line tool
Hydro will give you the option to continue without GitHub repository creation if neither tool is installed.
-g
or--github
to Initialize a new private GitHub repository and push your new project to it.
# Repository created at https://github.com/<your_github_username>/awesome-plugin
hydro new AwesomePlugin --github
- Use
--gh-public
with--github
to make the new GitHub repository public.
hydro new AwesomePlugin --github --gh-public
- Use
--gh-description
with--github
to initialize the new GitHub repository with a description.
hydro new AwesomePlugin --github --gh-description='My awesome Filament plugin'
- Use
--gh-homepage
with--github
to initialize the new GitHub repository with a homepage url.
hydro new AwesomePlugin --github --gh-homepage=https://example.com
- Use
--gh-org
with--github
to initialize the new GitHub repository with a specified organization.
# Repository created at https://github.com/acme/awesome-plugin
hydro new AwesomePlugin --github --gh-org=acme