Forums / General / How would YOU make this in eZ publish?

How would YOU make this in eZ publish?

Author Message

Jonny Bergkvist

Monday 15 September 2003 2:24:35 am

Hi!

We have several small classical database-applications on our old web made manually with php+custom mysql-tables.

We hope we can put the content of many of these into eZ.

1 illustrating example:
---------------------------

We have 5 (book-)libraries here at Telemark University College at different geographic locations. All have magazine-collections, and they want to have have a web-app. to store the following information of each magazine:

* name of magazine
* subject area (from a prefefined selection of areas, ie: computing, health, science)
* library (which of the 5 libraries have this magazine)
* ...some other details about each magazine, just straight-forward class-attributes...

The library want these functions:
* limit search to 1 of the libraries
* limit search to 1 subject area
* limit search to both of the above limits

I hope YOU could tell me and other forum-users how you would make such a typical database-application with eZ publish classes, templates, and content structure

I believe this is at very common 'case'; how to put typical relational database content into eZ publish.

Paul Forsyth

Monday 15 September 2003 5:48:20 am

You are right, this is a common case where ez publish can be used very effectively.

I would suggest you begin by reading the documentation and plan out the structure of your classes, objects and what templates you need. It is probably quicker for you to start with this rather than forum users giving you detailed instructions about what to do. You will learn quicker too :)

If you do have problems do post to the forums. We know a lot about problems :)

Paul

Jonny Bergkvist

Tuesday 16 September 2003 12:56:59 am

Thanks for answer Paul :-)

First, I am not new to eZ publish, but still I wonder how to do some special things in the best way.

I can try to ask more directly;

With 1 predefined category-list (ie. subject-area: computing, health, science...) I would make folders with these names, and put magazines into the right folder.

With 2 (or more) predefined category-lists (subject area + a list of 5 locations) i get more uncertain whats the best solution.
I think I would use folders for subject-area, and store the location into a class-attribute in the magazine-class, and then make some smart template-code that store and fetch ie. a value from a combo-box. This will make a user-friendly interface, but I don't like the thought of having to make custom templates also for the admin sitedesign.

Am I thinking right? I don't like the thought of having to make custom templates for the admin-part... So I hope there is easier ways of doing this.

Jonny

Paul Forsyth

Tuesday 16 September 2003 1:32:00 am

You don't need to alter the standard admin classes for your use. You may want to if you need to change the admin but i don't think you need to at this stage. Consider the following.

If i read you right you could make a class with these attributes (essentials for now, but you can add more).

Magazine:

- name (textline)
- category (multi-line enum)
- libraries (multi-line enum)

The name will be a simple textline. The category i've classes as a multi line enumeration since some of your magazines may fall into two categories but you can class it as a single if your categories are distinct.

The libraries are a multi line enumeration. When you create an object for this class you can decide which libraries the magazines are in. If another library gets the magazine then just update the object.

This means you could just have a single folder within the admin to hold all of magazine objects. On your user side you can present the information in any way you want, sort by category, whatever.

However, you may choose to use your idea of a folder per category. In this case i suggest maybe keeping the category field just to handle the cases where the magazine is in more than one category, and note it when displaying the objects in your folder category. But you can get rid of it if you wish.

I've tried to show the flexibility you have for your problem. Again, it is a standard use of ez and once you begin to use it you should start to see of other ways to present your data. When i started my designs changed by the hour. Now im a little better, i change them every few days ;) Well, when im designing that is!

Paul

Jonny Bergkvist

Tuesday 16 September 2003 3:15:44 am

Thanx a lot Paul!

Strange that I never have discovered/tested the enum-datatype.

That was certainly my "missing link" :-)

Now back to do the work!

Jonny

Bård Farstad

Tuesday 16 September 2003 3:49:58 am

Jonny, I would look into the selection datatype. It's faster than enum and does basically the same.

Enum is a bit slow on larger sites.

--bård

Documentation: http://ez.no/doc

Thomas Brandl

Tuesday 16 September 2003 4:41:10 am

If you should run into problems with selection, have a look at http://ez.no/developer/ez_publish_3/bug_reports/selection_datatype_new_options_cannot_be_added

eZ debug

Timing: Jan 18 2025 11:22:23
Script start
Timing: Jan 18 2025 11:22:23
Module start 'content'
Timing: Jan 18 2025 11:22:24
Module end 'content'
Timing: Jan 18 2025 11:22:24
Script end

Main resources:

Total runtime1.2014 sec
Peak memory usage4,096.0000 KB
Database Queries210

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0076 587.7266180.8359
Module start 'content' 0.00760.9930 768.5625668.7891
Module end 'content' 1.00060.2008 1,437.3516341.0625
Script end 1.2014  1,778.4141 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00490.4041210.0002
Check MTime0.00170.1421210.0001
Mysql Total
Database connection0.00080.069410.0008
Mysqli_queries1.109592.35272100.0053
Looping result0.00280.23562080.0000
Template Total1.166697.120.5833
Template load0.00200.169220.0010
Template processing1.164596.928720.5823
Template load and register function0.00010.008310.0001
states
state_id_array0.00090.074210.0009
state_identifier_array0.00260.219620.0013
Override
Cache load0.00180.1506620.0000
Sytem overhead
Fetch class attribute can translate value0.00120.098850.0002
Fetch class attribute name0.00150.128990.0002
XML
Image XML parsing0.00150.128950.0003
class_abstraction
Instantiating content class attribute0.00000.0017110.0000
General
dbfile0.00470.3911340.0001
String conversion0.00000.000630.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
4content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
7content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
12content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
5content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 30
 Number of unique templates used: 6

Time used to render debug report: 0.0002 secs