xslain/laravel-modules-livewire 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

xslain/laravel-modules-livewire

最新稳定版本:3.0.1

Composer 安装命令:

composer require xslain/laravel-modules-livewire

包简介

Using Laravel Livewire in Laravel Modules package with automatically registered livewire components for every modules.

README 文档

README

Using Laravel Livewire in Laravel Modules package with automatically registered livewire components for every modules.

laravel-modules-livewire

Example Source Code: https://github.com/xslain/laravel-modules-livewire-example

Example Live Demo: https://dev.xslain.com/laravel-modules-livewire-example

Installation:

Install through composer:

composer require xslain/laravel-modules-livewire

Publish the package's configuration file:

php artisan vendor:publish --tag=modules-livewire-config

Making Components:

Command Signature:

php artisan pagemodule:make-livewire <Component> <Module> --view= --force --inline --stub= --custom

Example:

php artisan pagemodule:make-livewire Pages/AboutPage Core
php artisan pagemodule:make-livewire Pages\\AboutPage Core
php artisan pagemodule:make-livewire pages.about-page Core

Force create component if the class already exists:

php artisan pagemodule:make-livewire Pages/AboutPage Core --force

Output:

COMPONENT CREATED  🤙

CLASS: Modules/Core/Livewire/Pages/AboutPage.php
VIEW:  Modules/Core/Resources/views/livewire/pages/about-page.blade.php
TAG: <livewire:core::pages.about-page />

Inline Component:

php artisan pagemodule:make-livewire Core Pages/AboutPage --inline

Output:

COMPONENT CREATED  🤙

CLASS: Modules/Core/Livewire/Pages/AboutPage.php
TAG: <livewire:core::pages.about-page />

Modifying Stubs:

Publish the package's stubs:

php artisan vendor:publish --tag=modules-livewire-stub

After publishing the stubs, will create these files. And when running the make command, will use these stub files by default.

stubs/modules-livewire/livewire.inline.stub
stubs/modules-livewire/livewire.stub
stubs/modules-livewire/livewire.view.stub

You're able to set a custom stub directory for component with (--stub) option.

php artisan pagemodule:make-livewire Core Pages/AboutPage --stub=about
php artisan pagemodule:make-livewire Core Pages/AboutPage --stub=modules-livewire/core
php artisan pagemodule:make-livewire Core Pages/AboutPage --stub=./

Extra Option (--view):

You're able to set a custom view path for component with (--view) option.

Example:

php artisan pagemodule:make-livewire Pages/AboutPage Core --view=pages/about
php artisan pagemodule:make-livewire Pages/AboutPage Core --view=pages.about

Output:

COMPONENT CREATED  🤙

CLASS: Modules/Core/Livewire/Pages/AboutPage.php
VIEW:  Modules/Core/Resources/views/livewire/pages/about.blade.php
TAG: <livewire:core::pages.about-page />

Rendering Components:

<livewire:{module-lower-name}::component-class-kebab-case />

Example:

<livewire:core::pages.about-page />

Custom Module:

To create components for the custom module, should be add custom modules in the config file.

The config file is located at config/modules-livewire.php after publishing the config file.

Remove comment for these lines & add your custom modules.

    /*
    |--------------------------------------------------------------------------
    | Custom modules setup
    |--------------------------------------------------------------------------
    |
    */

    // 'custom_modules' => [
    //     'Chat' => [
    //         'path' => base_path('libraries/Chat'),
    //         'module_namespace' => 'Libraries\\Chat',
    //         // 'namespace' => 'Livewire',
    //         // 'view' => 'Resources/views/livewire',
    //         // 'name_lower' => 'chat',
    //     ],
    // ],

Custom module config details

path: Add module full path (required).

module_namespace: Add module namespace (required).

namespace: By default using config('modules-livewire.namespace') value. You can set a different value for the specific module.

view: By default using config('modules-livewire.view') value. You can set a different value for the specific module.

name_lower: By default using module name to lowercase. If you set a custom name, module components will be register by custom name.

License

Copyright (c) 2021 Mehediul Hassan Miton xslain.dev@gmail.com

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 57
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-11-20