Forums / Developer / How can i add Java Script + PHP to a single web page?

How can i add Java Script + PHP to a single web page?

Author Message

Lupusoru Razvan

Wednesday 16 December 2009 9:56:02 am

Hi,

I have this interractive map.It is built in java and needs to use PHP to import some data from MySQL.All examples i have seen are built using templates. I donn't need anything fancy.I only have this single page and nothing else. I tryed adding code between the 'literal' tags in the page editor, but the code is duplayed and i get an error like <script> tag not recognised.

Thanks

Gaetano Giunta

Wednesday 16 December 2009 3:17:10 pm

You will need to create either

- a new template operator

- a new template function

- a custom module and view

the standard way of operation of eZ Publish is "no way to execute php from templates"

Principal Consultant International Business
Member of the Community Project Board

Nicolas Pastorino

Monday 25 January 2010 1:34:40 pm

Hi and welcome in the eZ Community,

Resuscitating this slightly old topic, could you describe a bit more what your application would consist of ?

What kind of data do you need to push to the interactive map ?
How is the data represented in the backend (using the content engine or not, if yes what datatypes, etc..) ?
Is data stored in eZ Publish at all ?

Let us know,
Cheers,

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Brandon Chambers

Monday 25 January 2010 3:12:04 pm

Nicolas is right, the standard way of interacting/working with eZ is to use higher-level languages such as the template code and HTML. Although, you can create new modules and extensions which usually involve using PHP/JavaScript/XML for more technical interactions with eZ. Otherwise the functionality you need can probably be used with eZ Publish "right out of the box".

Furthermore, I recently had a project in which I used the Google JavaScript API for converting a rough-sketch interaction you are talking about to a more elegant solution for a client. The pre-existing solution involved using a separate database to store business locations and their information (phoone number, street address, URL, etc).

So the interaction model looks like this:

> User enters City/State into search field and selects a distance radius in miles (it's an American-based client)

> On submission, JavaScript function is called

> Call Google API

> Call PHP class for AJAX interaction (to populate map with location information)

> PHP class queries database to retrieve data based on user input (calculates radius and whatnot as well)

> Save information to XML object

> return XML object tp JavaScript

> Populate map with retrieved information

This can be done using a simple template override and no template code as you asked..

Again, a more elaborate solution might involve the GMaps location object (an extension) with eZ Find. I think that would match the eZ Publish interaction model a bit closer, make your code more readable, as well as debugging much easier all because this solution would have a much clearer segmentation of code.

Good luck and I hope this helps.

Brandon Chambers
brandon@granitehorizon.com
blog: http://blog.divdesigns.com
Granite Horizon / http://granitehorizon.com

Sergi A

Wednesday 10 February 2010 1:21:23 am

"

Furthermore, I recently had a project in which I used the Google JavaScript API for converting a rough-sketch interaction you are talking about to a more elegant solution for a client. The pre-existing solution involved using a separate database to store business locations and their information (phoone number, street address, URL, etc).

So the interaction model looks like this:

> User enters City/State into search field and selects a distance radius in miles (it's an American-based client)

> On submission, JavaScript function is called

> Call Google API

> Call PHP class for AJAX interaction (to populate map with location information)

> PHP class queries database to retrieve data based on user input (calculates radius and whatnot as well)

> Save information to XML object

> return XML object tp JavaScript

> Populate map with retrieved information

This can be done using a simple template override and no template code as you asked..

"

That's very similar to my case... I have the picture but i don't know exactly where to start.. i mean, i have an ajax call using the GMaps API GDownload function:

GDownloadUrl(url, function(...) ...

the 'url' should be a php script that would retrieve information from database and return it in xml ... but how can I do it taking into account the ezPublish model... should the PHP be a class, where should it be located, and how can I interact with the database directly?

thank you,

Sergi.

eZ debug

Timing: Jan 18 2025 02:55:17
Script start
Timing: Jan 18 2025 02:55:17
Module start 'content'
Timing: Jan 18 2025 02:55:18
Module end 'content'
Timing: Jan 18 2025 02:55:18
Script end

Main resources:

Total runtime1.3905 sec
Peak memory usage4,096.0000 KB
Database Queries206

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0059 587.8594180.8125
Module start 'content' 0.00591.1968 768.6719697.1641
Module end 'content' 1.20270.1877 1,465.8359341.0547
Script end 1.3904  1,806.8906 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00430.3078210.0002
Check MTime0.00150.1107210.0001
Mysql Total
Database connection0.00090.064310.0009
Mysqli_queries1.297693.31522060.0063
Looping result0.00270.19322040.0000
Template Total1.365498.220.6827
Template load0.00220.155120.0011
Template processing1.363298.035920.6816
Template load and register function0.00020.016810.0002
states
state_id_array0.00080.055010.0008
state_identifier_array0.00100.073120.0005
Override
Cache load0.00190.1398560.0000
Sytem overhead
Fetch class attribute can translate value0.00130.094760.0002
Fetch class attribute name0.00210.148780.0003
XML
Image XML parsing0.00240.173960.0004
class_abstraction
Instantiating content class attribute0.00000.001580.0000
General
dbfile0.00620.4443390.0002
String conversion0.00000.000430.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
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
5content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
8content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
3content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
2content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/datatype/view/ezxmltags/quote.tpldatatype/ezxmltext/quote.tplextension/ezwebin/design/ezwebin/override/templates/datatype/ezxmltext/quote.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 21
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs