kwidoo/mere
最新稳定版本:1.1.2
Composer 安装命令:
composer require kwidoo/mere
包简介
Core menu and resource functionality
README 文档
README
`
Kwidoo Mere
Mere = Menu + Resource Reusable backend core for Laravel apps with Vue frontends, providing dynamic menu definitions, resource scaffolding, and centralized configuration for forms, validation, and permissions.
✨ Features
- 🌲 Menu definitions stored in DB (
MenuItem) - 🧩 Automatic props generation from model structure
- 🧪 Reusable validation rules across Laravel + Vue
- 🔐 Action-level permissions (create/edit/delete)
- 🧠 Shared base service for clean CRUD logic
- 📦 Uses
Prettus Repository,Fractal,NestedSet - 🧰 Includes Artisan command for syncing menu structure
⚙️ Installation
composer require kwidoo/mere
Optional config publish:
php artisan vendor:publish --provider="Kwidoo\Mere\MereServiceProvider"
📁 MenuItem Structure
The MenuItem model defines Vue frontend routes:
| Field | Description |
|---|---|
name |
Format: ResourceAction (e.g. PropertyList) |
path |
Vue route path (e.g. /properties) |
component |
Vue component name (GenericResource, GenericCreate, etc.) |
props |
Configuration for fields, rules, actions, and label |
Example:
{
"label": "properties",
"fields": [
{ "key": "name", "label": "Name", "sortable": true, "visible": true }
],
"rules": {
"name": "required|string|max:255"
},
"actions": {
"create": true,
"edit": true,
"delete": false
}
}
🧪 Syncing Menus via Artisan
You can auto-generate menu definitions using your model and form requests:
php artisan mere:sync-menu --resource=Property
This will:
- Use
App\Models\Property's$fillableand$appendsforfields - Extract rules from
PropertyCreateandPropertyUpdateFormRequests - Generate or update the following
MenuItems:PropertyListPropertyCreatePropertyUpdate
You can override the default Vue component:
php artisan mere:sync-menu --resource=Property --component=MyCustomPage
🧰 BaseService
Extendable abstract service with automatic:
- Repository injection
- Validation
- CRUD event dispatching
class PropertyService extends BaseService { protected function eventKey(): string { return 'property'; } }
📦 ResourceController
Generic controller for all resource endpoints. Works with:
GET /api/{resource} GET /api/{resource}/{id} POST /api/{resource} PUT /api/{resource}/{id} DELETE /api/{resource}/{id}
Bind the service using a middleware or config map:
// config/mere.php 'resources' => [ 'property' => \App\Services\PropertyService::class, ]
🧱 BaseRequest
Dynamic rules resolver:
// POST /api/property => PropertyCreate // PUT /api/property/{id} => PropertyUpdate
It pulls rules from MenuService::getRules() using route segments.
🧠 Component Detection
Each MenuItem can specify a component such as:
GenericResource(list page)GenericCreate(create form)GenericUpdate(edit form)
This is saved as a top-level DB column and not inside props.
📚 API Overview
MenuService
getMenus(): Collection getFields(string $name): array getRules(string $name): array
ResourceCollection
(new ResourceCollection(...)) ->fields([...]) ->label('properties') ->canCreate(true)
🧪 Testing & Extensibility
- All services can be tested via Laravel’s container
- You can register custom presenters, validators, or transformers
- Easy to extend with custom menu fields, UI configs, or ACL logic
🚧 TODO
- Add granular permission checks
- Add support for
redirect,childrenin MenuItem tree - Sync command enhancements: guessing types, dry-run mode
- Optional: type-based component mapping
📃 License
MIT
统计信息
- 总下载量: 6
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-03-21