Forums / Developer / Customizing menu branches with own extension?

Customizing menu branches with own extension?

Author Message

Tobias S.

Thursday 30 July 2009 11:39:34 pm

Hello,

I'm about to use eZ Publish as application framework. The application will arrange large ammounts of rather tiny content, and provide additional features when viewing it. I'd like to attach those customized views directly to the normal node tree, thereby appearing in the menu side by side with normal views.

The node tree will look like

Main Node
   Normal View 1
      Some Articles
      Some Articles
      Some Articles
   Normal View 2
      Some Articles
      Some Articles
      Some Articles
   Custom View
      Some Articles
      Some Articles
      Some Articles

The Normal Views will be delivered as usual by the content module.

The Custom View should have additional features like filtering content, changing the display order, show additional information and whatever the app requires. Now, I'm not sure how to achieve this and what would be the best approach.

Can I somehow tie/attach my own module views to the custom view part of the tree, so it will be invoked instead of the content module? Or can I somehow "hook" into the content module to take over control, perhaps by using sections to distinguish between normal and custom views?

Any help or ideas are highly appreciated!

Cheers
Tobias

Gaetano Giunta

Friday 31 July 2009 1:32:16 am

It is not very clear to me if the 'custom view' section of your tree displays in a different way the content that actually lies in the other sections or if it just displays content that is in it in a different way.

Regardless of what you want to achieve, you can hook into the content module and take complete control of the output, as long as you take some precautions.
The advantage is that you get to keep the tree structure and the moving nodes around / renaming them / adding and deleting them capabilities for free.

You can use an override template for both the pagelayout and the node templates of your custom section, based on a variety of factors: a new section, the content class, view mode etc... (see http://ez.no/doc/ez_publish/technical_manual/4_0/reference/template_override_conditions)

Some useful tips might include:

- take care about view cache for 'meta' nodes, ie. nodes whose templates do not show information coming from the node itself but info coming from elsewhere. You should try to use the smart view cache to introduce proper dependencies or disable the view cache for them and try to introduce some cache blocks to reduce the load

- using a view mode as 'special mode' indicator forces you to use the system url of a node instead of the nice url, eg /content/view/mymode/64; You can set up wildcard url aliases to overcome that (and play around with the layout/set module, too)

- you might also code a full view for your nodes that, depending on a view parameter, includes via node_view_gui the template for another view mode, eg.
user url like my/custom/node/(view)/customized and in the template do

{if is_set($view-parameters.view)}
    {node_view_gui content_node=$node view=$view-parameters.view}
{else}
...
{/if}

- remember that by default only 'full' view mode benefits of view cache, but you can enable it for other view modes as well

- an 'http_header' template operator to do redirects from within template come can be handy, eg. for templates that redirect to other nodes views

Principal Consultant International Business
Member of the Community Project Board

Tobias S.

Friday 31 July 2009 2:36:40 am

Thanks for the quick reply, Gaetano. I'll keep all the hints in mind while developing my concept.

<i>> Regardless of what you want to achieve, you can hook into the content module and take complete control of the output, as long as you take some precautions.</i>

Yes, this is partially what I'd like to do. Template overriding is a great thing and will be very usefull of course! But I think I'll need more controll about the objects to display.

In concrete, I think of a tag cloud that is displayed aside the Custom View. As soon as the user clicks a tag, the currently viewed list will be reduced to display only the articles containing that certain tag. And the user may add more and more tags, until the list displays only articles he's interested in.

The tags have to be delivered dynamically, depending on what tags the user already has selected. I suspect this is too much for a simple template override, thus I would prefer some kind of PHP hook instead of just another view mode.

Tobias S.

Friday 31 July 2009 5:00:24 am

Well, in the meantime I decided to not generate the list views dynamically. Instead I'll generate the "custom view" navigation structure during cron cycles and let the content module serve it, as that's what it does perfectly. Spares me lots of caching considerations by the way :)

<b>A single question of this topic is still open (or perhaps I didn't recognize the answer):</b>

Can module views be attached to nodes, for a developer to benefit of the convenience the admin site and defaut menu system of eZ Publish provides?

Or (to make clear what I suspect) is the only solution to statically link my module's views from inside the templates and therefore, do I have to apply changes to the template code and won't benefit from the admin site's node tree interfaces?

Gaetano Giunta

Friday 31 July 2009 7:08:25 am

You cannot easily attach a module view to a node template - using a tpl operator that does http redirects might be one way, but I think that's not what you like to have.

You can from within a module's view code redirect to another ez view, but that is the opposite (you coudl from your custom view redirect to a node's content view).

But you can wrap the code for your custom views in nice separate content classes, and then expose it for easy reuse as template operators or fetch functions.

And nothing prevents you to include the templates done for custom views within node view templates.

Principal Consultant International Business
Member of the Community Project Board

Tobias S.

Friday 31 July 2009 7:43:08 am

I see. Thanks for pointing at fetch functions... overriding the proper content views and calling a module using {fetch} seems to be a very clean solution.

eZ debug

Timing: Jan 18 2025 15:19:24
Script start
Timing: Jan 18 2025 15:19:24
Module start 'content'
Timing: Jan 18 2025 15:19:24
Module end 'content'
Timing: Jan 18 2025 15:19:24
Script end

Main resources:

Total runtime0.1433 sec
Peak memory usage2,048.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0055 587.8438180.8125
Module start 'content' 0.00560.0045 768.6563102.0547
Module end 'content' 0.01000.1331 870.7109531.3750
Script end 0.1432  1,402.0859 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00322.2581200.0002
Check MTime0.00130.8766200.0001
Mysql Total
Database connection0.00080.568710.0008
Mysqli_queries0.103372.11281410.0007
Looping result0.00110.78671390.0000
Template Total0.132892.710.1328
Template load0.00080.535310.0008
Template processing0.132092.136110.1320
Override
Cache load0.00050.353810.0005
Sytem overhead
Fetch class attribute can translate value0.00090.638010.0009
XML
Image XML parsing0.00030.213610.0003
General
dbfile0.00251.7158200.0001
String conversion0.00000.004330.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0002 secs