Skip to content

Latest commit

 

History

History
229 lines (158 loc) · 9.07 KB

readme.md

File metadata and controls

229 lines (158 loc) · 9.07 KB

MaryGen Documentation

Table of Contents

  1. Introduction
  2. Features
  3. Requirements
  4. Installation
  5. Configuration
  6. Usage
  7. Command Structure
  8. Generated Components
  9. Customization
  10. Translation Feature
  11. Troubleshooting
  12. Contributing
  13. License
  14. Support

Introduction

MaryGen is a powerful Laravel package designed to streamline the process of generating MaryUI components and Livewire pages for your Laravel models. It automates the creation of CRUD (Create, Read, Update, Delete) interfaces, saving developers significant time and effort in setting up admin panels or data management systems.

Features

  • Automatic generation of MaryUI components for Laravel models
  • Creation of Livewire pages with full CRUD functionality
  • Intelligent form field generation based on database schema
  • Automatic table column generation
  • Built-in sorting, pagination, and search capabilities
  • Easy customization options
  • Automatic route generation
  • Translation support for generated content (new in version 0.35.0)

Requirements

Installation

  1. Ensure you have a Laravel project set up.

  2. Install the MaryUI:

    https://mary-ui.com/docs/installation

  3. Install the Livewire, Livewire Volt packages (if not already installed with MaryUI):

    composer require livewire/livewire livewire/volt && php artisan volt:install
  4. Install the MaryGen package:

    composer require soysaltan/marygen
  5. (Optional) Publish the configuration file:

    php artisan vendor:publish --provider="SoysalTan\MaryGen\MaryGenServiceProvider" --tag="config"

Configuration

After publishing the configuration file, you can modify config/marygen.php to customize the package behavior:

return [
    'model_namespace' => 'App\Models',
    'use_mg_like_eloquent_directive' => true,
];
  • model_namespace: Define the namespace for your models. Default is App\Models.
  • use_mg_like_eloquent_directive: Determine whether to use the MgLike Eloquent directive for search functionality. For example:
$q->mgLike(['id', 'username', 'email', 'password', 'name', 'lastname', 'title', 'phone', 'avatar', 'time_zone', 'last_login_at', 'status', 'created_at', 'updated_at'], $this->search))

Usage

To generate a MaryUI component and Livewire page for a model, use the following command:

php artisan marygen:make {--m|model=} {--w|view=} {--d|dest_lang=} {--s|source_lang=} {--nr|no-route}
  • --m|model: The name of the model for which you want to generate the components.
  • --w|view: (Optional) The name of the view file. If not provided, it will use the lowercase model name.
  • --d|dest_lang: (Required if source_lang presents) The destination language code for translation.
  • --s|source_lang: (Optional) The source language code for translation.If not present, it detects the source language automatically.
  • --nr|no-route: (Optional - as of v0.35.2) Prevent automatic route addition to routes/web.php.

Example:

php artisan marygen:make --model=User --view=admin-users --dest_lang=es --no-route

This command will generate a Livewire page for the User model with CRUD functionality, name the view file admin-users.blade.php, and translate the content from English to Spanish and skip the automatic route generation.

Prevent Automatic Route Generation (as of v0.35.2)

Starting from version 0.35.2, MaryGen prevents automatic route generation feature. By default, when you generate a new component without using --no-route option with the marygen:make command, a corresponding route is automatically added to your routes/web.php file.

New in Version 0.36.1: Multi-Database Connection Support

As of version 0.36.1, MaryGen now supports models that use different database connections. This feature allows you to generate components and pages for models that are associated with databases other than your default connection.

How it works

MaryGen now respects the $connection property of your Eloquent models. When generating components and pages, it will use the specified connection to:

  1. Retrieve the correct table schema
  2. Generate appropriate form fields
  3. Create table columns
  4. Set up sorting and filtering

Usage

No additional configuration is required. Simply ensure that your model specifies the correct connection:

class User extends Model
{
    protected $connection = 'secondary_db';

    // ... rest of your model
}

When you run the marygen:make command for this model, MaryGen will automatically use the 'secondary_db' connection for all database operations.

Example

php artisan marygen:make --model=User

If the User model specifies a different connection, MaryGen will use that connection to generate the component and page.

Notes

  • Ensure that all specified connections are properly configured in your config/database.php file.
  • If a model doesn't specify a connection, MaryGen will use the default database connection.
  • This feature is particularly useful for applications that interact with multiple databases or use database sharding.

Customization

You can customize the generated components by modifying the following methods in the MaryGenCommand class:

  • getMaryUIComponent(): Adjust the mapping between database column types and MaryUI components.
  • getIconForColumn(): Modify the icon selection for form fields.
  • generateLivewirePage(): Customize the structure of the generated Livewire component and Blade view.

Additionally, you can edit the generated files directly to further tailor them to your specific needs.

Translation Feature

MaryGen includes a translation feature that allows you to generate content in different languages. This feature uses the Google Translate API to translate field names, labels, and other text elements in the generated components. It uses stichoza/google-translate-php package. (https://github.com/Stichoza/google-translate-php) To use the translation feature:

  1. Specify the destination language using the --dest_lang option when running the marygen:make command.
  2. Optionally, specify the source language using the --source_lang option. If not provided, Google Translate will attempt to auto-detect the source language.

Example:

php artisan marygen:make --model=Product --view=product-management --dest_lang=fr --source_lang=en

This command will generate the components for the Product model and translate the content from English to French.

Note: The translation feature requires an active internet connection to communicate with the Google Translate API.

Troubleshooting

Common issues and their solutions:

  1. MaryUI package not found:

    • Error: MaryUI package not found! Please install using: 'composer req robsontenorio/mary'
    • Solution: Run composer require robsontenorio/mary to install the MaryUI package.
  2. Livewire Volt package not found:

    • Error: Livewire Volt package not found! Please see doc: 'https://livewire.laravel.com/docs/volt#installation'
    • Solution: Install Livewire Volt using composer require livewire/livewire livewire/volt && php artisan volt:install.
  3. Model not found:

    • Error: Model {modelName} does not exist!
    • Solution: Ensure the specified model exists in your model namespace (default: App\Models).
  4. View file already exists:

    • Error: File {viewName}.blade.php already exists!
    • Solution: Choose a different name for your view or manually delete the existing file if you want to overwrite it.
  5. Translation errors:

    • Error: Various Google Translate API errors
    • Solution: Ensure you have an active internet connection and that the language codes you're using are valid. Check the Google Translate documentation for supported language codes.
  6. Route generation issues:

    • Problem: Unwanted routes being added to routes/web.php
    • Solution: Use the --no-route option when running the marygen:make command to prevent automatic route generation.

Contributing

Contributions to MaryGen are welcome! Here's how you can contribute:

  1. Fork the repository
  2. Create a new branch for your feature or bug fix
  3. Write your code and tests
  4. Submit a pull request with a clear description of your changes

Please ensure your code adheres to the existing style conventions and includes appropriate tests.

License

MaryGen is open-source software licensed under the MIT license.

Support

For more information or support:

  • Open an issue on the GitHub repository
  • Contact the package maintainer through the repository's contact information

For the latest updates and more detailed information about MaryUI, please visit the official MaryUI documentation.