/symfony-wordpress-bundle

Mirror of Wildsea's fork of Symfony Wordpress Bundle

Primary LanguagePHPGNU Affero General Public License v3.0AGPL-3.0

Symfony WordPress Bundle

Build enterprise solutions with WordPress.

Latest Stable Version Total Downloads Latest Unstable Version License Buy us a tree Doc - Gitbook

How does it work ?

When the WordPress bundle is loaded, it includes the minimal amount of WordPress Core files to allow usage of WordPress functions and plugins inside Symfony.

Example :

// src/Controller/BlogController.php

/**
 * @param Post $post
 * @param PostRepository $postRepository
 * @return Response
 */
public function pageAction(Post $post, PostRepository $postRepository)
{
    $context = [];
    
    // get current post
    $context['post'] = $post;
    
    // find 10 "guide" ordered by title
    $context['guides'] = $postRepository->findBy(['post_type'=>'guide'], ['title'=>'ASC'], 10);

    return $this->render('page.html.twig', $context);
}
{# templates/page.html.twig #}

{% extends 'layout.html.twig' %}

{% block body %}
<article id="post-{{ post.ID }}" class="entry {{ post.class }}">

    {% if post.thumbnail %}
        <img src="{{ post.thumbnail|resize(800, 600) }}" alt="{{ post.thumbnail.alt }}"/>
    {% endif %}

    <div class="entry-content">
        
        {{ post.content|raw }}
        
        {# or #}
        
        {% for block in post.blocks %}
            {% include 'block/'~block.name~'.html.twig' %}
        {% endfor %}
    </div>
    
    <small>{{ post.custom_fields.mention }}</small>
    
    {% for guide in guides %}
        {% include 'guide.html.twig' with {props:guide} %}
    {% endfor %}

</article>
{% endblock body %}

Documentation

Full documentation is available on Gitbook

Features

Using Composer :

  • Install/update WordPress via composer
  • Install/update plugins via composer

Using Symfony :

  • Twig template engine
  • Folder structure
  • Http Cache
  • Routing
  • YML configuration
  • DotEnv
  • Enhanced Security ( WordPress is 'hidden' )
  • Dynamic image resize
  • MVC

Using WordPress Bundle :

  • Post/Term/User Repository
  • Controller argument resolver for post(s), term, user and blog
  • Symfony Cache invalidation on update ( Varnish compatible )
  • Post/PostCollection/Image/Menu/Term/User/Comment/Blog/Block entity
  • Possible use of WordPress predefined routes
  • Site health checker url

Using WP Steroids WordPress plugin :

  • WordPress' configuration using yml ( view sample )
  • Permalink configuration for custom post type and taxonomy
  • Maintenance mode
  • Backup download in dev mode
  • Build hook
  • Disabled automatic update
  • Enhanced Security
  • Better guid using RFC 4122 compliant UUID version 5
  • Multisite images sync ( for multisite as multilangue )
  • SVG Support
  • Better Performance
  • WordPress Bugfix
  • CSS Fix
  • Multisite post deep copy ( with multisite-language-switcher plugin )
  • Custom datatable support with view and delete actions in admin
  • Google translate or Deepl integration
  • Optimisations

YML file allows to configure :

  • Image options
  • Maintenance support
  • Admin pages removal
  • WYSIWYG MCE Editor
  • Feature Support
  • Multi-site configuration
  • ACF configuration
  • Menu
  • Custom Post type
  • Custom Taxonomy
  • Block
  • Page, post, taxonomy template
  • Page state
  • Post format
  • External table viewer
  • Advanced roles

Installation

Make sure Composer is installed globally, as explained in the installation chapter of the Composer documentation.

Creating a new project

$ composer create-project metabolism/wordpress-skeleton my_project_directory

Please read the full bundle installation guide to continue

Setting up an existing Symfony project

Define installation path for WordPress core and plugins in composer.json

"extra": {
    "installer-paths": {
        "public/wp-bundle/mu-plugins/{$name}/": ["type:wordpress-muplugin"],
        "public/wp-bundle/plugins/{$name}/": ["type:wordpress-plugin"],
        "public/wp-bundle/themes/{$name}/": ["type:wordpress-theme"],
        "public/edition/": ["type:wordpress-core"]
    }
}

Install the bundle

$ composer require metabolism/wordpress-bundle

For applications that don't use Symfony Flex

Register the bundle

// config/bundles.php

return [
    // ...
    Metabolism\WordPressBundle\WordPressBundle::class => ['all' => true],
];

Please read the full bundle installation guide to continue

Demo

https://github.com/wearemetabolism/wordpress-bundle-demo

This is an implementation of the Twenty Nineteen WordPress theme for wordpress-bundle.

Screenshot from 2021-05-03 10-08-22

Recommended / tested plugins

  • Advanced custom fields Customise WordPress with powerful, professional and intuitive fields.
  • ACF extensions Extensions for ACF
  • Classic editor Restores the previous (« classic ») WordPress editor and the « Edit Post » screen.
  • WP smartcrop Set the 'focal point' of any image, right from the media library
  • Multisite language switcher Add multilingual support using a WordPress multisite
  • WordPress seo The favorite WordPress SEO plugin of millions of users worldwide!
  • Query monitor Query Monitor is the developer tools panel for WordPress
  • Redirection Easily manage 301 redirections, keep track of 404 errors
  • Contact form 7 Manage multiple contact forms, plus you can customize the form and the mail contents

Roadmap

  • More samples
  • Global maintenance mode for multi-site
  • Unit tests
  • Better type hinting

Drawbacks

WordPress' functions are available in the global namespace.

Some WordPress plugins may not work ( ex : Woocommerce ) or require extra works.

Licence

GPL 3.0 or later

This package is Treeware. If you use it in production, then we ask that you buy the world a tree to thank us for our work. By contributing to the Treeware forest you’ll be creating employment for local families and restoring wildlife habitats.