kwidoo / mere
Core menu and resource functionality
Installs: 6
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/kwidoo/mere
Requires
- php: ^7.4|^8.0
- kalnoy/nestedset: ^6.0
- laravel/framework: ^10.0||^11.0||^12.0
- league/fractal: ^0.20.2
- prettus/l5-repository: ^2.10
Requires (Dev)
- mockery/mockery: ^1.6
- orchestra/testbench: ^10.1
- phpunit/phpunit: ^11.5
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:- PropertyList
- PropertyCreate
- PropertyUpdate
 
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