sau/wp-framework

Framework for fast dev plugin and template

Installs: 7

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/sau/wp-framework

dev-master 2019-02-08 09:38 UTC

This package is auto-updated.

Last update: 2025-10-09 01:04:47 UTC


README

Small framework for dev plugin or templates in WP

In base use Symfony framework(bundle):

Install

Framework mady install in plugin or template

First install pack:

composer require sau/wp-framework

Plugin install

Add this code in base file framework

use Sau\WP\Framework\Install\Install;
use Sau\WP\Framework\Install\Remove;

include_once __DIR__.'/vendor/autoload.php';

register_activation_hook (__FILE__, function(){
    Install::install(__DIR__);
});
register_deactivation_hook (__FILE__, function(){
    Remove::deactivate(__DIR__);
});

Theme install

Add this code in function.php file framework

use Sau\WP\Framework\Install\Install;
use Sau\WP\Framework\Install\Remove;

include_once __DIR__.'/vendor/autoload.php';

add_action('after_switch_theme', function(){
    Install::install(__DIR__);
});
add_action('switch_theme', function(){
    Remove::deactivate(__DIR__);
});

After Install

After install with activate plugin/theme. In project you see infrastructure

Start codding...

Extend

Base extend it's Bundle

If using base infrastructure use as symfony flex application

Action

If need extent plugin use actions:

do_action('before_boot_'.$name, $kernel); - before kernel load

do_action('after_boot_'.$name, $kernel); - after get response object (load kernel)

do_action('response_'.$name, $response); - after get response object. Use for modify response in framework

do_action('wp_response_'.$name, $response); - after create WP response (if route not found)

!!! Kernel load in action after_setup_theme in priority 99.

Use in wp template

If you need use kernel in your code:

global $sau_kernels;
//___name___ its name plugin/template 
$sau_kernels[ '___name___' ]->getContainer()
                           ->get('twig')
                           ->display('index.html.twig');