FireWire Posted August 26, 2024 Share Posted August 26, 2024 While working with RPB I have started to modify the stubs in the /modules/RockPageBuilder/stubs directory because, while the advanced block stub has been great, I realized that there is a lot of boilerplate that evolves into projects and I found myself consistently having to copy/paste contents from existing blocks to new blocks when created. I've been editing the stubs in the RPB module directory but have to be sure that I re-copy my custom stubs after upgrading the module. Perhaps there could be an option to "Publish Block Stubs" on the module configuration page. It could create a /templates/RockPageBuilder/stubs directory where the default stub files could be copied to and would be used for creating new blocks when they exist. I've created several support classes/objects that help with speed and consistency when working with blocks and having have new blocks created from customized files would be super awesome. Inspired by Laravel's publish stubs feature ? 1 Link to comment Share on other sites More sharing options...
bernhard Posted August 26, 2024 Share Posted August 26, 2024 Here you go: Quote # Custom Block Stubs ## Overview RockPageBuilder allows you to create custom "stub" files for generating new blocks. These stubs serve as boilerplate code, providing a consistent starting point for block creation. By default, the module offers two versions of stubs: 1. A commented version for beginners 2. An advanced version without comments for experienced users ## The Problem Every website has unique requirements, such as different CSS frameworks (Bootstrap, TailwindCSS, etc.) or project-specific markup. The default stubs may not always align with your project's needs, leading to: - Time-consuming cleanup and class modifications for each new block - Potential oversights in adding project-specific classes or structures - Inconsistencies across blocks, possibly introducing bugs ## The Solution: Custom Stubs To address these issues, RockPageBuilder allows you to create custom stub files tailored to your project's needs. ### How to Implement Custom Stubs 1. Create a directory: `/site/templates/RockPageBuilder/stubs/` 2. Add your custom stub files to this directory: - For PHP files: `.Block.php` (note the leading dot) - For view files: `.Block.latte` or `.Block.view.php` ### Example: Custom PHP Stub Create a file `/site/templates/RockPageBuilder/stubs/.Block.php`: ```php:site/templates/RockPageBuilder/stubs/.Block.php <?php namespace RockPageBuilderBlock; use RockPageBuilder\Block; class {name} extends Block { const prefix = "rpb_{namelower}_"; public function info() { return [ 'title' => '{name}', ]; } public function migrate() { $rm = $this->rockmigrations(); $rm->migrate([ 'fields' => [], 'templates' => [ $this->getTplName() => [ 'fields-' => [], ], ], ]); } } ``` ### Example: Custom View Stub (Latte) Create a file `/site/templates/RockPageBuilder/stubs/.Block.latte`: ```latte:site/templates/RockPageBuilder/stubs/.Block.latte <section class="{cls} tm-block {$site->bgClass}" {alfred($block)} > <div class='uk-container text-auto'> TBD </div> </section> ``` This example uses UIkit classes and includes a generic `tm-block` class and a `bgClass` from the global `$site` object. ## Benefits By using custom stubs, you can: 1. Ensure consistency across all blocks in your project 2. Reduce the time spent on initial block setup 3. Minimize the risk of forgetting project-specific classes or structures 4. Tailor the initial block code to your project's specific needs and coding standards Remember to adjust these custom stubs as your project evolves to maintain their relevance and effectiveness. This version will be merged next week. I'll send you a copy to test! 1 2 Link to comment Share on other sites More sharing options...
FireWire Posted August 26, 2024 Author Share Posted August 26, 2024 @bernhard Oh heck yeah!!! That's going to be a gamechanger for me and really appreciate it! 1 1 Link to comment Share on other sites More sharing options...
bernhard Posted August 26, 2024 Share Posted August 26, 2024 Great! This has been annoying me over the last few days as well (and on any previous project), but it was not annoying enough to have the idea of supporting custom stubs per project so your input was highly appreciated ? If any of you guys have any other suggestions how to further improve the day to day development experience when using RockPageBuilder please let me know! 4 Link to comment Share on other sites More sharing options...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now