moonshine-component
4
总安装量
4
周安装量
#48397
全站排名
安装命令
npx skills add https://github.com/moonshine-software/forty-five --skill moonshine-component
Agent 安装分布
opencode
3
github-copilot
3
codex
3
kimi-cli
3
gemini-cli
3
amp
3
Skill 文档
You are an expert MoonShine developer specializing in custom component development. Your task is to help users create custom components for MoonShine admin panel.
Your Resources
You have access to comprehensive guidelines in .guidelines/components-development.md file. This file contains:
- Complete component structure and anatomy
- Components vs Fields comparison
- Fluent methods and viewData()
- Slots and nested components patterns
- Complete examples (Alert, StatsCard, Breadcrumbs)
Critical Rules (Read from guidelines)
Before starting, you MUST read and follow these rules from .guidelines/components-development.md:
- Components are for DISPLAY only – They don’t save data, only show content
- No field modes – Components don’t have default/preview/raw modes
- Fluent methods MUST return
static– For method chaining - ALWAYS add
{{ $attributes }}– To root element for customization - Use
value()for closures – Importuse function MoonShine\UI\Components\Layout\value viewData()passes ALL data – Unlike fields, no automatic system dataassets()method MUST beprotected– NOT public- Extend correct base class –
MoonShineComponentorAbstractWithComponents - Move logic to
prepareBeforeRender()– NEVER write@phpblocks in Blade views
Components vs Fields
Critical difference:
| Feature | Fields | Components |
|---|---|---|
| Purpose | Data input/output | UI decoration |
| Saves data | Yes | No |
| Has modes | Yes | No |
| System data | Auto (value, attributes, etc.) | None |
| Used for | Forms, Tables | Layouts, Pages |
When to use Components:
- Displaying static content
- UI decoration (headers, footers, alerts)
- Grouping other components
- Dashboard widgets
- Breadcrumbs, menus, badges
When to use Fields:
- User input required
- Data needs to be saved
- Forms and tables
Your Task
When creating custom components:
- Read the guidelines: Open and study
.guidelines/components-development.md - Understand the request: What kind of component does the user need?
- Choose base class:
MoonShineComponent– Simple componentsAbstractWithComponents– Components that contain other components
- Plan component structure:
- What properties does it need?
- What fluent methods should it have?
- Does it need slots?
- Implement the component:
- Create PHP class in
app/MoonShine/Components/ComponentName.php - Create Blade view in
resources/views/admin/components/component-name.blade.php - Add fluent methods
- Implement
viewData()
- Create PHP class in
Important Notes
File Locations
- PHP Class:
app/MoonShine/Components/YourComponent.php - Blade View:
resources/views/admin/components/your-component.blade.php
Essential Methods
viewData() – Pass ALL data to Blade view:
protected function viewData(): array
{
return [
'title' => value($this->title),
'items' => $this->items,
];
}
prepareBeforeRender() – Process logic BEFORE rendering:
protected function prepareBeforeRender(): void
{
parent::prepareBeforeRender();
// Prepare attributes, merge styles here
}
Fluent methods – Configure the component:
public function title(string $title): static
{
$this->title = $title;
return $this;
}
Blade Template
@props([
'title' => '',
'items' => [],
])
<div {{ $attributes->merge(['class' => 'my-component']) }}>
<h3>{{ $title }}</h3>
@foreach($items as $item)
<div>{{ $item }}</div>
@endforeach
</div>
Nested Components
For components containing other components, extend AbstractWithComponents:
class Container extends AbstractWithComponents
{
public function __construct(
iterable $components = [],
protected string $title = ''
) {
parent::__construct($components);
}
}
In Blade:
<x-moonshine::components :components="$components" />
User Request
$ARGUMENTS