How to re-use assets provided by the default view.

This is a community-contributed tutorial. This tutorial is over a year old and may not apply to your version of Concrete CMS.
Mar 7, 2016

Edited

Hold on with this tutorial for a bit. I found some issues on updated concrete5 installs. I'll investigate further asap. When using this Trick, the assets will be searched in updates/concrete5version/packages...

Original:

Problem:

Sometimes you would like to re-use those assets you created for your normal view. And would only make small changes on your template. But the original assets are no longer auto-loaded. Only the assets in your template map are. Of course you could create a copy, or include them, but that has a number of disadvantages (speed, double loading, upgrades)

Situation:

  • custom block with auto-loaded assets in myblock/css and myblock/js:
    • myblock/css/myblock.css
    • myblock/js/myblock.js
  • a template in /templates/myblock/myblocktemplate:
    • view.php
    • view.css
    • view.js

Goals:

  • re-use and extend on the assets loaded by the normal view template.
  • use concrete5's asset system so files don't get loaded twice (no @import or addheader)

Trick:

  • use the same asset handle as the autoloader does. You might expect them to be something like: 'blocks/myblock', but they have the full name of the asset -> 'blocks/myblock/myblock.js'

block controller:

    public function on_start()
    {
        $al = \Concrete\Core\Asset\AssetList::getInstance();
        $al->register('css', 'blocks/myblock/myblock.css','../packages/myblock/blocks/myblock/css/image_plus.css');
        $al->register('javascript', 'blocks/myblock/myblock.js', '../packages/myblock/blocks/myblock/js/myblock.js');
        $al->registerGroup('blocks/myblock', array(
            array('css', 'blocks/myblock/myblock.css'),
            array('javascript', 'blocks/myblock/myblock.js')
        ));
    }

and:

    public function registerViewAssets($outputContent = '')
    {
        $this->requireAsset('blocks/myblock');
    }

Now, these original assets are also loaded when you apply a myblocktemplate on your block. In templates/myblock/myblocktemplate you can override or extend them.

Recent Tutorials
How To Add Page Last Updated To Your Concrete CMS Pages
Mar 7, 2023

Concrete CMS has a page attribute you can add to a global area called "Page Date Modified." Here's how to add it

How To Exclude Subpages from Navigation
Dec 24, 2022

How to exclude subpages from navigation - useful for a news or blog link in your main navigation where you don't want all the subpages to appear in a drop down menu.

How Can I Change The Maximum Size Of Uploaded files
Dec 13, 2022

This tutorial explains how to update your php settings.

Updating Concrete Themes from Version 8 to Version 9
Nov 24, 2022

This tutorial covers commonly encountered issues when upgrading a Concrete CMS theme from version 8 to version 9

Transferring ownership of an add-on and a theme
Nov 15, 2022
By katzueno.

If you encounter a Concrete CMS add-on or theme that you love but not being maintained, you may want to ask the author to help or take over the add-on or theme. Here is the quick step-by-step guide of how to transfer the ownership.

How to update Add-Ons if not on the Update Add-Ons Menu item
Jul 4, 2022

How to manually download an add-on and update it when your site's core versions isn't considered compatible with the add-on version.

Was this information useful?
Thank you for your feedback.