Fetch and display shopping basket of current user

Author Message

Sejal Paliwal

Friday 28 November 2008 2:03:23 am

I used the fetch function as described in the documentation. Have used the following code to display shopping basket of current user on every product page.


{def $basket=fetch( 'shop', 'basket' )}
 
{if $basket.is_empty}
 
    There are no products in the basket.
 
{else}
 
    There are {count( $basket.items )} items in the basket.  <br />
    Total price (ex. VAT) :  {$basket.total_ex_vat|l10n( currency )} <br />
    Total price (inc. VAT):  {$basket.total_inc_vat|l10n( currency )}<br>

     <strong>{$total_inc_shipping_ex_vat|l10n( 'currency', $locale, $symbol )}</strong>
 
{/if}

{undef $basket}

This outputs the result for the first time but when adding more items "i.e after clicking the continue shopping button", the code does not update the count and total from shopping basket.

Please guide me with the code.

Thanks in advance!

Arnaud Lafon

Monday 01 December 2008 4:26:09 am

Hi Sejal,

Are you using this code in the pagelayout (or a template included in) or in the template that is used to display your product (an override of node/view/full.tpl...) ?

Looking for information about SQLI ?
Looking for a new job in Paris ?
Please contact me at alafon [at] sqli [dot] com

Pascal Specht

Monday 01 December 2008 6:41:42 am

Hi Sejal,

try adding this line at the top of your product template:

{set-block scope=global variable=cache_ttl}0{/set-block}

If this works, it means that the data is cached and therefore not updated...

</Pascal>

Sejal Paliwal

Monday 01 December 2008 7:32:44 pm

Yes it works! :)

Thanks a lot!!!

Arnaud Lafon

Tuesday 02 December 2008 1:03:08 am

Hi Sejal,

If disabling view caching is working, this means that your basket fetch is done in a view template (an override of node/view/*.tpl)... If you don't want to experience some performance issues, you should replace your code in the pagelayout or in a template included in...

Also check SQL queries count in the debug.

Regards

Looking for information about SQLI ?
Looking for a new job in Paris ?
Please contact me at alafon [at] sqli [dot] com

Sejal Paliwal

Tuesday 02 December 2008 9:45:08 pm

Hi Arnaud,

As suggested by Pascal, I had added the following code to my node/view/full.product.tpl.

{set-block scope=global variable=cache_ttl}0{/set-block}

And now it is working fine.

You guessed it right that I added the code in the view template.
But, you specified of some performance issues and replace the code in the pagelayout or in a template included. I didnt get to know what to do, being a newbie to eZ Publish.

I would appreciate if you could explain me what is wrong or should I let the code in node/view/full/product.tpl?

Thanks in Advance!

Regards

Arnaud Lafon

Wednesday 03 December 2008 5:00:52 am

Hi Sejal,

If the product pages represent a large proportion of the visited pages on your site, then they will have an impact on your server load. And If these pages, without caching, generates a lot of MySQL queries, then you'll have serious problems... (how many queries do you have in the ezdebug ?). It's common to say that an ez content page with view caching should generate from 2 to 6 sql queries maximum...

Actually, disabling view caching without adding some cache-block isn't a good solution. As far as you're concerned, adding some cache-block won't be a good solution too, cuz you'll have to expire the cache-block each time something is done in the user basket...

So you have 2 solutions :
- doing your basket fetch in the pagelayout.tpl, and doing this not in a cache-block...
- If you want to do your fetch in the content view template, then how about doing this with some ajax ?

Looking for information about SQLI ?
Looking for a new job in Paris ?
Please contact me at alafon [at] sqli [dot] com

Sejal Paliwal

Wednesday 03 December 2008 8:02:27 pm

Hi Arnaud,

Thank you so much for your kind support!

Well, you are right that my count of SQL queries have tremendously increased after disabling the view caching.

So, finally I have pasted the code in the new override for pagelayout.tpl. and thankfully it is working fine.
But, now I have to work on the CSS so as to lay it on a proper position. Is there any way that the fetch basket block and my main content are placed inline?

A part of my pagelayout.tpl ->

 <!-- Main area content: START -->

<div class="rttop">  // positions it on right top corner
<fetch basket code>
</div>
 {$module_result.content}

          <!-- Main area content: END -->

I can only place it either above or below the main area. How can I position it on the top-right area of the main content so that the header of the product class and the block of fetch basket has the same top margin.

Thanks again!

Regards

Arnaud Lafon

Thursday 04 December 2008 2:12:26 am

Sorry Sejal, I'm really bad in CSS :D

Looking for information about SQLI ?
Looking for a new job in Paris ?
Please contact me at alafon [at] sqli [dot] com

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 11:15:16
Script start
Timing: Jan 18 2025 11:15:16
Module start 'layout'
Timing: Jan 18 2025 11:15:16
Module start 'content'
Timing: Jan 18 2025 11:15:17
Module end 'content'
Timing: Jan 18 2025 11:15:17
Script end

Main resources:

Total runtime1.3913 sec
Peak memory usage4,096.0000 KB
Database Queries77

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0101 588.0625152.6406
Module start 'layout' 0.01010.0030 740.703139.4766
Module start 'content' 0.01301.3769 780.1797655.2813
Module end 'content' 1.38990.0014 1,435.460920.1250
Script end 1.3913  1,455.5859 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00480.3435160.0003
Check MTime0.00270.1950160.0002
Mysql Total
Database connection0.00150.110810.0015
Mysqli_queries1.308194.0204770.0170
Looping result0.00070.0531750.0000
Template Total1.357497.620.6787
Template load0.00400.289120.0020
Template processing1.353497.270920.6767
Template load and register function0.00020.013510.0002
states
state_id_array0.00080.056110.0008
state_identifier_array0.00140.099520.0007
Override
Cache load0.00370.2657620.0001
Sytem overhead
Fetch class attribute can translate value0.00050.037730.0002
Fetch class attribute name0.00130.0967110.0001
XML
Image XML parsing0.00110.079730.0004
class_abstraction
Instantiating content class attribute0.00010.0074140.0000
General
dbfile0.00200.1435230.0001
String conversion0.00000.000640.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
9content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
17content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
4content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
5content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
5content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 42
 Number of unique templates used: 7

Time used to render debug report: 0.0001 secs