Plugin Service Provider
As mentioned in creating a plugin section, each plugin has one main class which basically serves as a service provider for the plugin. Like any other service provider it has two default methods that you can use for registering plugin related stuff: register and boot.
Vanguard plugins have one more default method called sidebar, and it's purpose is to allow you to easily put the navigation items to Vanguard's sidebar navigation.
The Register Method
As per Laravel docs,
within the register
method, you should only bind things into
the service container. For example,
this is a perfect place to bind some concrete repository classes to a specific
interface.
The Boot Method
This method is called after all other service providers have been registered, meaning you have access to all other services that have been registered by the framework. Inside this method you will bind your plugin routes, register views, etc.
The Sidebar Method
If your plugin needs to add an item to the sidebar, this is the method where you will define how this sidebar item will look like and who should be able to see it.
The method returns an instance of the Vanguard\Support\Sidebar\Item
class
and it's recommended to open the class definition itself and go through all
the documented methods to see everything that this class can do. Here is an
example on how to define a sidebar item for our "Foo" plugin created above:
public function sidebar()
{
return Item::create('Foo')
->icon('fas fa-bullhorn')
->route('foo.index')
->permissions('foo.manage')
->active('foo*');
}
The create
factory method from above accepts a string which is basically
the title of the navigation item printed inside the sidebar.
The icon
method is actually FontAwesome icon class that should be used for
the item.
The route
method is a named route to which this navigation item should
point to. If you don't have a named route for this navigation item, or you
simply want to point to some external URL, you can use the href
method
that accepts any string that will be used for a href
attribute for a navigation link.
The permissions
method is where you define permissions required for viewing
the sidebar item. It accepts either a single permission as a string, array of
permissions or even a callback that you can use if you have some complex
authorization logic.
If a callback provided here returns true
then currently authenticated user
will be able to see the navigation item. Otherwise it won't be rendered. Here is an
example:
Item::create('Foo')
->permissions(function ($user) {
return $user->status === 'Foo';
})
//...
The active
method is where you define when this navigation item should be
active according to the current URL path. In our case from above, this item
will be active whenever there is an URL that starts with foo
.