AI prompts
base on A Laravel Development Package for Creating Enums, Traits, Services Classes and more . # Laravel Maker: A Laravel Development Package for Creating Classes , Enums, Traits, Services Classes and more .
[![Latest Version on Packagist](https://img.shields.io/packagist/v/ammaraldwayma/laravel-maker.svg?style=flat-square)](https://packagist.org/packages/ammaraldwayma/laravel-maker)
[![Total Downloads](https://img.shields.io/packagist/dt/ammaraldwayma/laravel-maker.svg?style=flat-square)](https://packagist.org/packages/ammaraldwayma/laravel-maker)
**Laravel Maker** is a powerful Laravel development package designed to help you to enhance your development process by
creating Classes , Enums, Traits, Interfaces, Services and more with a single command.
With Laravel Maker you can create the following classes:
- [Classes](#creating-a-new-class)
- [Enums](#creating-a-new-enum)
- [Traits](#creating-a-new-trait)
- [Interfaces](#creating-a-new-interface)
- [Services](#creating-a-new-service--third-party-service)
- [Repositories](#creating-a-new-repository)
## Installation
You can install the package via composer:
```bash
composer require ammaraldwayma/laravel-maker --dev
```
## Usage
### Creating a new Class
```bash
php artisan make:class Actions/StoreUserAction
```
This command will create a new class in the `app/Actions` directory. The class will be named `StoreUserAction` and will
contain the following code:
```php
<?php
namespace App\Actions;
class StoreUserAction
{
}
```
### Creating a new Enum
```bash
php artisan make:enum Statuses
```
This command will create a new enum class in the `app/Enums` directory. The class will be named `Statuses` and will
contain the following constants:
```php
<?php
namespace App\Enums;
enum Statuses: string
{
//
}
```
[//]: # (You can also specify the values of the constants by passing them as arguments to the command:)
[//]: # ()
[//]: # (```bash)
[//]: # (php artisan make:enum Statuses PENDING APPROVED REJECTED)
[//]: # (```)
[//]: # ()
[//]: # (This will create the following enum class:)
[//]: # ()
[//]: # (```php)
[//]: # (<?php)
[//]: # ()
[//]: # (enum Statuses: string)
[//]: # ({)
[//]: # ( case PENDING = 'PENDING';)
[//]: # ( case APPROVED = 'APPROVED';)
[//]: # ( case REJECTED = 'REJECTED';)
[//]: # (})
[//]: # (```)
### Creating a new Trait
```bash
php artisan make:trait HasStatus
```
This command will create a new trait class in the `app/Traits` directory. The class will be named `HasStatus` and will
contain the following code:
```php
<?php
namespace App\Traits;
trait HasStatus
{
//
}
```
### Creating a new Interface
```bash
php artisan make:interface UserRepositoryInterface
```
This command will create a new interface class in the `app/Interfaces` directory. The class will be
named `UserRepository` and will contain the following code:
```php
<?php
namespace App\Interfaces;
interface UserRepositoryInterface
{
//
}
```
### Creating a new Service / Third-party Service
```bash
php artisan make:service GoogleTranslationService
```
This command will create a new service class in the `app/Services` directory. The class will be
named `GoogleTranslationService` and will contain the following code:
```php
<?php
namespace App\Services;
class GoogleTranslationService
{
/**
* @param PendingRequest $httpClient
* @param array $serviceKeys
*/
public function __construct(
protected PendingRequest $httpClient,
protected array $serviceKeys = [],
)
{
$this->serviceKeys = config('services.google_translation');
$this->httpClient = Http::asJson()
->acceptJson()
->withoutVerifying()
->baseUrl($this->serviceKeys['base_url'])
->timeout($this->serviceKeys['timeout']);
}
/**
* Get {{ name }} data .
*
* @param array $data
* @return array
*/
public function get(array $data = []): array
{
$response = $this->httpClient->get('/');
if ($response->failed()) {
return [
'status' => false,
'data' => [],
];
}
return [
'status' => true,
'data' => $response->json(),
];
}
}
```
### Creating a new Repository
```bash
php artisan make:repo UserRepository
```
This command will create a new repository class in the `app/Repositories` directory with a interface class in the
`app/Repositories/Interfaces` directory. The class will be named `UserRepository` and will contain the following code:
```php
<?php
namespace App\Repositories;
use App\Repositories\Interfaces\UserRepositoryInterface;
use App\Models\User;
class UserRepository implements UserRepositoryInterface
{
/**
* @param User $user
*/
public function __construct(
protected User $user,
)
{
//
}
}
```
## Customizing the default namespaces
You can customize the default namespaces for the different types of classes that you can generate it by the package by
- Publishing the config file:
```bash
php artisan vendor:publish --tag="maker-config"
```
- Changing the values of the `default_namespaces` array in the published config file:
```php
return [
/*
|--------------------------------------------------------------------------
| Default Namespaces
|--------------------------------------------------------------------------
| Here you can specify the default namespaces for the different types of
| classes that you can generate it by the package.
|
*/
'default_namespaces' => [
'enum' => 'App\Enums',
'trait' => 'App\Traits',
'interface' => 'App\Interfaces',
'service' => 'App\Services',
'repository' => 'App\Repositories',
],
];
```
## Testing
```bash
composer test
```
## Changelog
Please see [CHANGELOG](CHANGELOG.md) for more information on what has changed recently.
## License
The MIT License (MIT). Please see [License File](LICENSE.md) for more information.
", Assign "at most 3 tags" to the expected json: {"id":"6744","tags":[]} "only from the tags list I provide: [{"id":77,"name":"3d"},{"id":89,"name":"agent"},{"id":17,"name":"ai"},{"id":54,"name":"algorithm"},{"id":24,"name":"api"},{"id":44,"name":"authentication"},{"id":3,"name":"aws"},{"id":27,"name":"backend"},{"id":60,"name":"benchmark"},{"id":72,"name":"best-practices"},{"id":39,"name":"bitcoin"},{"id":37,"name":"blockchain"},{"id":1,"name":"blog"},{"id":45,"name":"bundler"},{"id":58,"name":"cache"},{"id":21,"name":"chat"},{"id":49,"name":"cicd"},{"id":4,"name":"cli"},{"id":64,"name":"cloud-native"},{"id":48,"name":"cms"},{"id":61,"name":"compiler"},{"id":68,"name":"containerization"},{"id":92,"name":"crm"},{"id":34,"name":"data"},{"id":47,"name":"database"},{"id":8,"name":"declarative-gui "},{"id":9,"name":"deploy-tool"},{"id":53,"name":"desktop-app"},{"id":6,"name":"dev-exp-lib"},{"id":59,"name":"dev-tool"},{"id":13,"name":"ecommerce"},{"id":26,"name":"editor"},{"id":66,"name":"emulator"},{"id":62,"name":"filesystem"},{"id":80,"name":"finance"},{"id":15,"name":"firmware"},{"id":73,"name":"for-fun"},{"id":2,"name":"framework"},{"id":11,"name":"frontend"},{"id":22,"name":"game"},{"id":81,"name":"game-engine "},{"id":23,"name":"graphql"},{"id":84,"name":"gui"},{"id":91,"name":"http"},{"id":5,"name":"http-client"},{"id":51,"name":"iac"},{"id":30,"name":"ide"},{"id":78,"name":"iot"},{"id":40,"name":"json"},{"id":83,"name":"julian"},{"id":38,"name":"k8s"},{"id":31,"name":"language"},{"id":10,"name":"learning-resource"},{"id":33,"name":"lib"},{"id":41,"name":"linter"},{"id":28,"name":"lms"},{"id":16,"name":"logging"},{"id":76,"name":"low-code"},{"id":90,"name":"message-queue"},{"id":42,"name":"mobile-app"},{"id":18,"name":"monitoring"},{"id":36,"name":"networking"},{"id":7,"name":"node-version"},{"id":55,"name":"nosql"},{"id":57,"name":"observability"},{"id":46,"name":"orm"},{"id":52,"name":"os"},{"id":14,"name":"parser"},{"id":74,"name":"react"},{"id":82,"name":"real-time"},{"id":56,"name":"robot"},{"id":65,"name":"runtime"},{"id":32,"name":"sdk"},{"id":71,"name":"search"},{"id":63,"name":"secrets"},{"id":25,"name":"security"},{"id":85,"name":"server"},{"id":86,"name":"serverless"},{"id":70,"name":"storage"},{"id":75,"name":"system-design"},{"id":79,"name":"terminal"},{"id":29,"name":"testing"},{"id":12,"name":"ui"},{"id":50,"name":"ux"},{"id":88,"name":"video"},{"id":20,"name":"web-app"},{"id":35,"name":"web-server"},{"id":43,"name":"webassembly"},{"id":69,"name":"workflow"},{"id":87,"name":"yaml"}]" returns me the "expected json"