The Structure of a Plugin

Each plugin needs a file structure. The rules for this file structure are easy to learn important to follow. Otherwise, the plugin won't work.

Basic Folder And File

A simple plugin works with one folder and one file. There are the following naming conventions:

So it might look like this:

/myPlugin  // folder
  - myPlugin.php  // file with plugin-code

Configuration File

However, if you want to distribute a plugin on the TYPEMILL website (not ready yet), then you must add a configuration file with YAML syntax, and this file must have the same name as the plugin again. This is very important, because the versioning and the update notifications, that are shown in the setup, only work with this configuration file.

So the minimum requirement for a distributed plugin looks like this:

/myPlugin // folder
  - myPlugin.php // file with plugin-code
  - myPlugin.yaml // file with yaml-configuration

Other files

You are free to add any other files and folders into your plugin. A plugin can have assets like images, CSS or JavaScript. It can also have templates, controllers and middleware. The folder structure of a more complex plugin might look like this:

- myPlugin.php 
- myPlugin.yaml
  - myController.php
  - myMiddleware.php
  - mytemplate.twig
  - mystyle.css
  - myscript.js
  - myimage.jpg