lin3s / wp-foundation
Helper classes for building WordPress theme in the LIN3S way
Installs: 15 707
Dependents: 1
Suggesters: 0
Security: 0
Stars: 5
Watchers: 2
Forks: 2
Open Issues: 3
Requires
- php: ^5.5 || ^7.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^1.11
- lin3s/wp-phpspec-brigde: ^0.1
- phpspec/phpspec: ^2.5
- dev-master
- v1.7.1
- v1.7.0
- v1.6.4
- v1.6.3
- v1.6.2
- v1.6.1
- v1.6.0
- v1.5.0
- v1.4.1
- v1.4.0
- v1.3.7
- v1.3.6
- v1.3.5
- v1.3.4
- v1.3.3
- v1.3.2
- v1.3.1
- v1.3.0
- v1.2.5
- v1.2.4
- v1.2.3
- v1.2.2
- v1.2.1
- v1.2
- v1.1.11
- v1.1.10
- v1.1.9
- v1.1.8
- v1.1.7
- v1.1.6
- v1.1.5
- v1.1.4
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.0
- dev-feature/fixed-issue-with-field-components
- dev-fix/no-name-field-component
- dev-refactor/fix-null-posttype-name
- dev-feature/refactor-and-simplify-post-types
- dev-feature/v2.0.0
- dev-fix/missing-file-headers
- dev-fix/spec-file-headers
- dev-fix/file-headers
- dev-fix/readme-styling
- dev-feature/update
This package is not auto-updated.
Last update: 2025-01-18 19:46:28 UTC
README
Helper classes for building WordPress theme in the LIN3S way
Why?
After implementing several WordPress themes, we built what we think can be considered as best practices building this kind of projects in a clean, consistent and fast way: thus was born LIN3S's WordPress Standard Edition. We are really happy with it, but there are some tasks that are very repetitive and tedious, furthermore each developer usually implements in a different way so, with this library we try to avoid these kind of troubles. At this moment, WPFoundation only contains a set of interfaces and abstract classes (in the future who knows :)) to force all developers to follow the same way becoming our code more consistent.
Installation
The recommended and the most suitable way to install is through Composer. Be sure that the tool is installed in your system and execute the following command:
$ composer require lin3s/wp-foundation
Usage examples
The following code snippets are representative code samples of how can it use this library:
- Ajax
- Configuration
- PostTypes
- Twig
- Widgets
Ajax
(...) use LIN3S\WPFoundation\Ajax\Ajax; final class MyAwesomeAjax extends Ajax { /** * {@inheritdoc} */ protected $action = 'my_awesome_ajax'; /** * {@inheritdoc} */ public function ajax() { (...) die('returning data'); } }
ACF
ACF configuration class, this class is responsible for all the logic about this WordPress plugin. A this moment this API only has one method that allows to have seamlessly multiple WYSWYG configuration for this type field used by ACF.
(...) use LIN3S\WPFoundation\Configuration\Acf\Acf; final class Acf extends BaseAcf { /** * {@inheritdoc} */ public function wyswygToolbars() { return [ 'basic' => [1 => ['bold', 'italic']], 'lin3s' => [1 => ['bold', 'italic', 'bullist', 'numlist', 'link', 'unlink']], ]; } }
Assets
(...) use LIN3S\WPFoundation\Configuration\Assets\Assets as BaseAssets; final class Assets extends BaseAssets { /** * {@inheritdoc} */ public function productionAssets() { $this ->addScript('app.min', self::BUILD_JS, ['jquery', 'jquery.counterup', 'sidr']); } /** * {@inheritdoc} */ public function developmentAssets() { $this ->addScript('jquery.sidr.min', self::VENDOR . '/sidr') ->addScript('waypoints', self::VENDOR . '/jquery-waypoints') ->addScript('jquery.counterup', self::VENDOR . '/Counter-Up') ->addScript('counter', self::ASSETS_JS, ['jquery', 'jquery.sidr.min', 'waypoints', 'jquery.counterup']) ->addScript('typekit', self::ASSETS_JS, [], '1.0.0', false) ->addScript('menu') ->addScript('accordion') ->addScript('post-ajax', self::ASSETS_JS, [], '1.0.0', false, 'postsAjax') } /** * {@inheritdoc} */ public function adminAssets() { $this->addStylesheet('adminCss'); $this->addScript('adminScript'); } }
Mailer
Mailer
class configures the way that emails are sent using wp_mail()
. You should configure the mailer parameters
editing the WordPress config file. Default parameters are given for the localhost smtp delivery.
You can define your own custom mailer that implements MailInterface
and uses wp_mail()
configuration selected
creating an instance of one of the two strategies above.
(...) use LIN3S\WPFoundation\Configuration\Mailer\MailInterface; use Timber; final class ContactMail implements MailInterface { /** * {@inheritdoc} */ public static function mail($request) { wp_mail( MAILER_TO, 'Contact' Timber::compile('mail/mail.twig', ['request' => $request]), ['Content-Type: text/html; charset=UTF-8'] ); } }
MailerInterface
is deprecated and will be removed in v2.0.0. Use wp_mail() directly to send the emails
Menus
// src/App/App.php use LIN3S\WPFoundation\Configuration\Menus\Menus class App extends Theme { public function classes() { (...) new Menus([ self::MENU_AWESOME => 'Awesome menu' ] } }
Theme
(...) use LIN3S\WPFoundation\Configuration\Theme\Theme; final class AwesomeTheme extends Theme { /** * {@inheritdoc} */ public function classes() { new Assets(); new Acf(); new Mailer(); new Menus(); new CustomPostType(); } /** * {@inheritdoc} */ public function templates($templates) { return array_merge($templates, [ 'index' => 'Index', 'customs' => 'Customs', ]); } /** * {@inheritdoc} */ public function context(array $context) { $context['mainMenu'] = new TimberMenu('main-menu'); $data['lang'] = ICL_LANGUAGE_CODE; return $context; } }
Translations
\LIN3S\WPFoundation\Configuration\Translations\Translations::trans('Your awesome string');
PostType
Declaring a post type is as easy as creating a new instance of PostType
.
// src/App/App.php class App extends Theme { public function classes() { (...) new PostType( PostTypes::CUSTOM_POST_TYPE, [ 'labels' => [ 'name' => Translations::trans('Exhibitions'), 'singular_name' => Translations::trans('Exhibition'), ], 'has_archive' => true, 'public' => true, 'publicly_queryable' => true, 'query_var' => true, 'show_in_rest' => true, 'show_ui' => true, 'supports' => ['title', 'editor', 'thumbnail'], ] ) } }
To add custom fields to a custom post type just create a Fields
instance:
// src/App/App.php class App extends Theme { public function classes() { (...) new Fields( PostTypes::CUSTOM_POST_TYPE, [ Fully\Qualified\Namespace\Components\CustomFieldComponent::class, ], new PostTypeFieldConnector(PostTypes::CUSTOM_POST_TYPE) ['editor'], ['comments'] ); } }
Fields
(...) use LIN3S\WPFoundation\PostTypes\Field\FieldComponent; final class CustomFieldComponent extends FieldComponent { /** * {@inheritdoc} */ public static function definition($aName) { return [ 'key' => sprintf('field_%s_component', $aName), (...) ]); } }
(...) use LIN3S\WPFoundation\PostTypes\Fields\PageFields as BasePageFields; final class PageFields extends BasePageFields { /** * {@inheritdoc} */ private $name = 'my_awesome_template; /** * {@inheritdoc} */ public function components() { return [ 'Fully\Qualified\Namespace\Components\CustomFieldComponent', ]; ]; }
RewriteRules
(...) use LIN3S\WPFoundation\PostTypes\RewriteRules\RewriteRules; final class CustomRewriteRules extends RewriteRules { /** * {@inheritdoc} */ public function rewriteRules() { add_rewrite_rule( '^custom-base-url/([^/]*)/([^/]*)/([^/]*)/?$', 'index.php?category=$matches[1]&subcategory=$matches[2]&custom=$matches[3]', 'top' ); add_rewrite_rule( '^custom-base-url/([^/]*)/([^/]*)/?$', 'index.php?category=$matches[1]&subcategory=$matches[2]', 'top' ); } /** * {@inheritdoc} */ public function rewriteTags() { add_rewrite_tag('%category%', '([^/]*)'); add_rewrite_tag('%subcategory%', '([^/]*)'); add_rewrite_tag('%custom%', '([^/]*)'); } /** * {@inheritdoc} */ public function templateInclude($template) { $controller = new CustomController(); $method = ''; if (get_query_var('category') !== '' && get_query_var('subcategory') !== '' && get_query_var('custom') != '' ) { $method = 'showAction'; } elseif (get_query_var('category') !== '' && get_query_var('subcategory') !== '' ) { $method = 'listAction'; } return $method === '' ? $template : $controller->$method(); } }
TagManagerTwig
After instantiate the the TagManagerTwig
in your theme, you can just call as following:
(...) {% block tagManager %} {{ tagManager('GTM-XXXXXX') }} {% endblock %}
TranslationTwig
After instantiate the the TranslationTwig
in your theme, you can just call as following:
(...)
{{ trans('Your awesome string') }}
Widget
(...) use LIN3S\WPFoundation\Widgets\Widget; final class SocialNetworksWidget extends Widget { /** * {@inheritdoc} */ public function widget($args, $instance) { $data = [ 'beforeWidget' => $args['before_widget'], 'afterWidget' => $args['after_widget'], 'beforeTitle' => $args['before_title'], 'afterTitle' => $args['after_title'], 'twitterUrl' => (!empty($instance['twitterUrl'])) ? strip_tags($instance['twitterUrl']) : '', 'facebookUrl' => (!empty($instance['facebookUrl'])) ? strip_tags($instance['facebookUrl']) : '', 'pinterestUrl' => (!empty($instance['pinterestUrl'])) ? strip_tags($instance['pinterestUrl']) : '', 'youtubeUrl' => (!empty($instance['youtubeUrl'])) ? strip_tags($instance['youtubeUrl']) : '', 'rssUrl' => (!empty($instance['rssUrl'])) ? strip_tags($instance['rssUrl']) : '', ]; return Timber::render('widgets/front/socialNetworks.twig', $data); } /** * {@inheritdoc} */ public function form($instance) { $instance['widgetNumber'] = $this->number(); $instance['widgetName'] = $this->name(); return Timber::render('widgets/admin/socialNetworks.twig', $instance); } /** * {@inheritdoc} */ public function update($newInstance) { $instance = [ 'twitterUrl' => (!empty($newInstance['twitterUrl'])) ? strip_tags($newInstance['twitterUrl']) : '', 'facebookUrl' => (!empty($newInstance['facebookUrl'])) ? strip_tags($newInstance['facebookUrl']) : '', 'pinterestUrl' => (!empty($newInstance['pinterestUrl'])) ? strip_tags($newInstance['pinterestUrl']) : '', 'youtubeUrl' => (!empty($newInstance['youtubeUrl'])) ? strip_tags($newInstance['youtubeUrl']) : '', 'rssUrl' => (!empty($newInstance['rssUrl'])) ? strip_tags($newInstance['rssUrl']) : '', ]; return $instance; } }
Widget Areas
(...) use LIN3S\WPFoundation\Widgets\Areas\WidgetArea; final class CustomWidgetArea extends WidgetArea { /** * {@inheritdoc} */ public function widgetArea() { register_sidebar([ 'name' => 'Custom widgets', 'id' => 'custom-widgets', 'before_widget' => '<section class="custom-widget">', 'after_widget' => '</section>', 'before_title' => '<h5>', 'after_title' => '</h5>', ]); } }