Home >Backend Development >PHP Tutorial >How to Build an OctoberCMS Widget Plugin

How to Build an OctoberCMS Widget Plugin

Christopher Nolan
Christopher NolanOriginal
2025-02-18 12:47:10178browse

This article delves into building an OctoberCMS backend widget plugin, expanding on basic plugin creation. We'll develop a "Quick Note" widget, mirroring WordPress's quick draft functionality.

How to Build an OctoberCMS Widget Plugin

Key Concepts:

  • Plugin scaffolding with php artisan create:plugin.
  • Extending the User model to manage user-specific notes.
  • Implementing a Report Widget (QuickNoteWidget) for the backend dashboard.
  • Defining widget properties (defineProperties) for customization (e.g., hiding the note list, changing the title).
  • Utilizing controllers and models for form handling, note management (CRUD operations).

Building the Quick Note Widget:

We'll create a widget that allows users to quickly add and manage short notes directly from their OctoberCMS dashboard.

How to Build an OctoberCMS Widget Plugin How to Build an OctoberCMS Widget Plugin

1. Plugin Setup:

Generate the plugin using the command line:

<code class="language-bash">php artisan create:plugin RAFIE.quicknote</code>

Update Plugin.php with plugin details:

<code class="language-php">public function pluginDetails()
{
    return [
        'name'        => 'Quick Note Widget',
        'description' => 'Quickly add and manage short notes.',
        'author'      => 'RAFIE Younes',
        'icon'        => 'icon-pencil'
    ];
}</code>

And the version.yaml:

<code class="language-yaml"># uploads/version.yaml
1.0.1: First version of quicknote
1.0.2:
  - Created Notes Table
  - create_notes_table.php</code>

2. Database Model:

Create the Note model and migration:

<code class="language-bash">php artisan create:model RAFIE.quicknote Note</code>

The migration (create_notes_table.php) will look like this:

<code class="language-php">Schema::create('rafie_quicknote_notes', function ($table) {
    $table->engine = 'InnoDB';
    $table->increments('id');
    $table->string('title', 255);
    $table->text('description')->nullable();
    $table->integer('user_id')->unsigned()->index();
    $table->timestamps();
});</code>

Refresh the plugin:

<code class="language-bash">php artisan plugin:refresh RAFIE.quicknote</code>

Extend the User model in Plugin.php:

<code class="language-php">public function boot()
{
    User::extend(function ($model) {
        $model->hasMany['notes'] = ['RAFIE\Quicknote\Models\Note'];
    });
}</code>

The Note model (models/Note.php):

<code class="language-php">use October\Rain\Database\Traits\Validation;

class Note extends Model
{
    use Validation;

    public $table = 'rafie_quicknote_notes';

    protected $guarded = ['*'];

    protected $rules = [
        'title' => 'required|min:4'
    ];

    public $belongsTo = ['user' => ['Backend\Models\User']];
}</code>

3. Widget Creation:

Create QuickNoteWidget.php (within the widgets folder):

<code class="language-php">class QuickNoteWidget extends ReportWidgetBase
{
    public function render()
    {
        $notes = BackendAuth::getUser()->notes;
        return $this->makePartial('notes', ['notes' => $notes]);
    }

    public function defineProperties()
    {
        return [
            'title' => [
                'title' => 'Widget Title',
                'default' => 'Quick Note'
            ],
            'showList' => [
                'title' => 'Show Notes List',
                'type' => 'checkbox'
            ]
        ];
    }
}</code>

Register the widget in Plugin.php:

<code class="language-php">public function registerReportWidgets()
{
    return [
        'RAFIE\Quicknote\QuickNoteWidget' => [
            'label' => 'Quick Notes',
            'context' => 'dashboard'
        ]
    ];
}</code>

Create the partial _notes.htm (in widgets/quicknotewidget/partials):

<code class="language-html"><div class="report-widget">
    <h3>{{ $this->property('title') }}</h3>
    <div class="pane">
        @if ($this->property('showList'))
            <ul class="list-nostyle">
                @foreach ($notes as $note)
                    <li class="list-group-item">{{ $note->title }}</li>
                @endforeach
            </ul>
        @endif
        <br>
        {{ Form::open(['url' => Backend::url('rafie/quicknote/notes/store'), 'method' => 'POST']) }}
        <div class="form-group">
            <input class="form-control" type="text" name="title" placeholder="Title" required>
        </div>
        <div class="form-group">
            <textarea class="form-control" name="description" id="" cols="30" rows="10" placeholder="Your note..."></textarea>
        </div>
        <div class="form-group">
            <button type="submit" class="btn btn-primary" value="Submit">Submit</button>
            <a href="https://www.php.cn/link/b4c174fbc208372a8facfe462868ebf1'rafie/quicknote/notes/index')%20%7D%7D">Manage your notes</a>
        </div>
        {{ Form::close() }}
    </div>
</div></code>

How to Build an OctoberCMS Widget Plugin

4. Controller (controllers/Notes.php):

<code class="language-php">class Notes extends Controller
{
    public function store()
    {
        $note = new Models\Note;
        $note->title = Input::get('title');
        $note->description = Input::get('description', null);
        $note->user_id = BackendAuth::getUser()->id;

        if ($note->save()) {
            Flash::success('Note added successfully.');
        } else {
            Flash::error('Validation error');
        }

        return Redirect::to(Backend::url());
    }

    // ... (rest of the controller code as described in the original response) ...
}</code>

Remember to complete the remaining controller actions (index, create, update, delete) and their associated configuration files (config_list.yaml, config_form.yaml, columns.yaml, fields.yaml, partials) as detailed in the original response. The image showing the controller structure is helpful:

How to Build an OctoberCMS Widget Plugin

5. Backend List and Form Configuration:

Configure the backend listing and form using config_list.yaml and config_form.yaml as shown in the original response. Pay close attention to the listExtendQueryBefore method in the controller to ensure only the current user's notes are displayed. The screenshot of the form configuration is useful:

How to Build an OctoberCMS Widget Plugin

This detailed breakdown should help you build the Quick Note widget. Remember to consult the OctoberCMS documentation for further assistance and to adapt the code to your specific needs. The FAQs at the end of the original response provide additional helpful information for working with OctoberCMS.

The above is the detailed content of How to Build an OctoberCMS Widget Plugin. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn