Forums / Developer / add ajax functionality to user interface

add ajax functionality to user interface

Author Message

Dhaval Patel

Monday 04 February 2008 9:24:23 pm

hi all,

i have developed one site.

in that there are mainly three columns

1. left column (menu)
2. middle column (content)
3. right column(block)

now i want the paging at right column side block with ajax.

i have done this with javascript only temperarely.

but i want it using ajax only.

please any one help me.

With Best Regards,

Dhaval Patel
Team Leader - iNETProcess(I) Pvt. LTD.
dhaval.patel@inetprocess.com
Ph No: +91 79 65 12 35 00
http://www.inetprocess.co.in

André R.

Tuesday 05 February 2008 12:40:32 am

So you want to get the content asynchronous as XML?..

eZ Online Editor 5: http://projects.ez.no/ezoe || eZJSCore (Ajax): http://projects.ez.no/ezjscore || eZ Publish EE http://ez.no/eZPublish/eZ-Publish-Enterprise-Subscription
@: http://twitter.com/andrerom

Dhaval Patel

Tuesday 05 February 2008 1:00:01 am

Thank you for replying André

now i have right column (view of frontpage).

In that there is a listing of the sub items of that frontpage.

now if the list is of more then 4 articles then paging should be there.

and the data is coming from database.

With Best Regards,

Dhaval Patel
Team Leader - iNETProcess(I) Pvt. LTD.
dhaval.patel@inetprocess.com
Ph No: +91 79 65 12 35 00
http://www.inetprocess.co.in

André R.

Tuesday 05 February 2008 8:49:07 am

You have to look into a couple of things:
* creating you own module / view (in a extension) to get content from the database and display it
* alternatively you can look into using layout/set to set a different layout for the content you get with ajax and combine that with a custom view (see sitemap for example). url will look something like "domain.com/layout/set/ajax/content/view/menu/55" where 55 is the node_id
* modify you right menu to call this module or special url ( using xmlhttprequest ) when you page the menu.

eZ Online Editor 5: http://projects.ez.no/ezoe || eZJSCore (Ajax): http://projects.ez.no/ezjscore || eZ Publish EE http://ez.no/eZPublish/eZ-Publish-Enterprise-Subscription
@: http://twitter.com/andrerom

Paul Leclercq

Wednesday 06 February 2008 3:35:12 pm

Like andré said you will need to create a custom view/module for your left page.

If you use "prototype" you will be able to do something like this:

let say this will be the basic structure of your page:

<script include..... prototype.js />

<div id="leftcol"></div>
<div id="main"></div>
<div id="righcol"></div>

<script type="text/javascript">
var tmp = new Ajax.Updater('leftcol", {"/mymodule/myleftcol"|ezurl('single')});
tmp = new Ajax.Updater('main", {"/mymodule/main"|ezurl('single')});
tmp = new Ajax.Updater('rightcol", {"/mymodule/myrightcol"|ezurl('single')});
</script>

The "prototype" API will allow you to a div which has an id very simply like this:
new Ajax.Updater('leftcol", {"/mymodule/myrightcol"|ezurl('single')});

Which you can use in your links:

<a href="#" onclick="tmp = new Ajax.Updater('leftcol', {concat("mymodule/myleftcol/(option)/", $option)|ezurl('single')})">update left col</a>

or export into javascript function and then reuse in your links:

myfunction.js

function mylink(option1){
var tmp = new Ajax.Updater('leftcol", "/mymodule/myleftcol/(page)/"+ option1);
}
<a href="#" onclick="mylink(option1)">update left col</a>

More info on this fonction here:
http://www.prototypejs.org/api/ajax/updater

Download prototype here:
http://www.prototypejs.org/download

An ajax view is generaly very simple since it will just update a small part of your page:
the following lines should be all you need for your simple view files, main.php/myleftcol.php/myrightcol.php (which you would put in the "/extension/your_module_s_name/modules/"'s directory):

<?php
include_once( 'kernel/common/template.php' );
$tpl =& templateInit();

$tpl->setVariable( 'view_parameters', $Params['UserParameters'] );

$Result = array();
$Result['pagelayout'] = false;
$Result['content'] = $tpl->fetch( $template );
?>

replace $template with the url of your template and you are set.

Your module.php file can also be very basic:

<?php
$Module = array( 'name' => 'mymodule' ,
                 'variable_params' => true );

$ViewList = array();
$ViewList['myleftcol'] = array( 'script' => 'myleftcol.php');
$ViewList['main'] = array( 'script' => 'main.php');
$ViewList['myrightcol'] = array( 'script' => 'myrightcol.php');
?>

this will give you a basic pagelayour with nothing in it which is ideal for simple blocs which will be udated and will avoid you from having to create your own view.

The attentive minds will have noticed that in this exemple I have passed on the view_parameters which will allow you to keep the same functionality as with node templates. By passing on functionnality to your template using the /(param)/ methods, this will allow you to include paging on to your menu ( url/(offset)/xxx )

I recommend reading this if you get a little lost:
http://ez.no/ezpublish/documentation/development/extensions/building_an_ez_publish_module

Good luck with that,

let us know how you get on.

Xavier Dutoit

Thursday 07 February 2008 3:44:31 am

It provides a generic interface to query / fetch node and a js library to display them (have a look at the included exemples)

http://projects.ez.no/json

http://www.sydesy.com

eZ debug

Timing: Jan 20 2025 20:10:54
Script start
Timing: Jan 20 2025 20:10:54
Module start 'content'
Timing: Jan 20 2025 20:10:54
Module end 'content'
Timing: Jan 20 2025 20:10:54
Script end

Main resources:

Total runtime0.1551 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.0064 587.8438180.8125
Module start 'content' 0.00640.0043 768.6563102.0547
Module end 'content' 0.01070.1443 870.7109530.3750
Script end 0.1550  1,401.0859 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00322.0883200.0002
Check MTime0.00130.8365200.0001
Mysql Total
Database connection0.00080.539610.0008
Mysqli_queries0.112072.22251410.0008
Looping result0.00120.75231390.0000
Template Total0.143992.810.1439
Template load0.00080.506710.0008
Template processing0.143192.293910.1431
Override
Cache load0.00050.337310.0005
Sytem overhead
Fetch class attribute can translate value0.00070.465710.0007
XML
Image XML parsing0.00020.123810.0002
General
dbfile0.00634.0833200.0003
String conversion0.00000.005230.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.0001 secs