定制 mgahed/laravel-starter 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

mgahed/laravel-starter

最新稳定版本:v1.3.7

Composer 安装命令:

composer require mgahed/laravel-starter

包简介

This is my package laravel-starter

README 文档

README

Packagist Version Packagist Downloads Packagist License Packagist PHP Version Support Packagist Stars

The package mgahed/laravel-starter allows you to easily use starter templates for your Laravel projects.

This is a PHP Package made to serve a plain Laravel project, This package add authentication and (view, edit, delete) profile using Saul theme. And you can easily customize and use the theme features in your project.

Warning

Please note that this package is still in development.

Installation

composer require mgahed/laravel-starter

Publishing

assets

php artisan vendor:publish --tag="mgahed-laravel-starter-assets"

This will add folder assets to the public path in your Laravel project.

migrations

php artisan vendor:publish --tag="mgahed-laravel-starter-migrations"

seeders

php artisan vendor:publish --tag="mgahed-laravel-starter-seeders"

Running Migrations

php artisan migrate --path=database/migrations/mgahed-laravel-starter

Running Seeders

php artisan db:seed --class=Mgahed\LaravelStarter\Database\Seeders\MgahedStarterSitesSeeder
php artisan db:seed --class=Mgahed\LaravelStarter\Database\Seeders\MgahedStarterMenusSeeder

Features supported

  • Authentication
  • Profile (view, edit, delete)
  • Easy translation system with multi-language support
  • Automated translation job (see Translation Job Guide)
  • Menu management system with multi-language support
  • Saul Theme supported
  • Easy to customize
  • Supports mcamara/laravel-localization package
    • Run composer require mcamara/laravel-localization
    • publish the config file php artisan vendor:publish --provider="Mcamara\LaravelLocalization\LaravelLocalizationServiceProvider"
    • See docs here

Menu Management System

The package includes a powerful menu management system that supports multi-language menu titles. Menu titles are stored as JSON in the database and automatically integrate with mcamara/laravel-localization package.

Creating a New Menu Item

Use the mgahed:menu command to create menu items with multi-language support:

php artisan mgahed:menu {slug} {route?} {parent?}

Parameters:

  • slug (required): The unique slug for the menu item
  • route (optional): The route name or URL (defaults to "#")
  • parent (optional): The parent menu slug (for creating sub-menus)

Interactive Multi-Language Input:

The command automatically detects available languages from your mcamara/laravel-localization configuration and prompts you to enter the menu title for each language:

# Create a simple menu item
php artisan mgahed:menu products products.index

# Create a parent menu
php artisan mgahed:menu settings-parent

# Create a child menu with parent
php artisan mgahed:menu site-settings settings.index settings-parent

Example Output:

Please enter the menu title for each language:
Title for English (en): Products
Title for Arabic (ar): المنتجات
Title for German (de): Produkte

Successfully created menu with id: 5
+----------+------------+
| Language | Title      |
+----------+------------+
| en       | Products   |
| ar       | المنتجات  |
| de       | Produkte   |
+----------+------------+

How it works:

  1. The command reads available languages from config/laravellocalization.php
  2. Prompts you to enter a title for each configured language
  3. Stores the titles as JSON in the database using spatie/laravel-translatable
  4. If no localization config is found, defaults to English and Arabic

Database Structure:

Menu titles are stored as JSON in the title column:

{
  "en": "Dashboard",
  "ar": "لوحة التحكم",
  "de": "Armaturenbrett"
}

This allows seamless integration with all Mgahed packages that support multi-language features like mgahed/ai, mgahed/core, mgahed/one, etc.

Translation System

The package includes a powerful translation job that can automatically translate your content to multiple languages using Google Translate API. The job integrates seamlessly with mcamara/laravel-localization to support all configured locales.

Translation Scanning

The translation scanner automatically discovers translation keys from your code and vendor packages. for example if you have alot of packages under mgahed By default, it scans:

  • Application views and controllers
  • All vendor packages under the mgahed namespace (configurable)

Scanning Multiple Vendor Packages

You can configure the package prefix to scan all packages under a specific vendor namespace. This is useful when you have multiple packages like mgahed/ai, mgahed/core, mgahed/one, etc.

Configuration:

Add to your .env file:

PACKAGES_PREFIX=mgahed

How it works:

The scanner will automatically discover and scan all packages under vendor/{PACKAGES_PREFIX}/:

  • Scans resources/views directory in each package
  • Scans src directory in each package
  • No need to manually configure each package

Example:

If you have the following packages:

  • vendor/mgahed/ai
  • vendor/mgahed/core
  • vendor/mgahed/one
  • vendor/mgahed/laravel-starter

All of them will be automatically scanned for translation keys without additional configuration.

Running the Scan:

use Mgahed\LaravelStarter\Jobs\ScanTranslationJob;

// Dispatch the job to scan for translation keys
ScanTranslationJob::dispatch();

Quick Start

use Mgahed\LaravelStarter\Jobs\TranslateJob;

// Translate from English to all supported languages
TranslateJob::dispatch('en');

// Translate from English to specific languages
TranslateJob::dispatch('en', ['ar', 'fr', 'es']);

For detailed usage instructions, see the Translation Job Guide.

Supported Links

Support me by clicking the button below

统计信息

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

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 1
  • 开发语言: JavaScript

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-03-02