Forums / Developer / select field for object relation

select field for object relation

Author Message

Kai Duebbert

Monday 04 August 2003 12:35:48 am

Hi,

I have the following situation:
1. A class with several object relation fields
2. Objects for these fields can only be selected from a specified directory.
3. Instead of doing the complicated way which the admin area uses, I want to use a select field.

Building the page with the right select values etc. all went fine. But what values do I have to give the select structure so that the objects get saved?

Other than the variables for the select field, the following code (seems to) work(s):

{section name=top loop=fetch( content, list, hash( parent_node_id, 104, class_filter_type, include, class_filter_array, array( 1 ) ) )}

{section show=eq($:item.name,$attribute.contentclass_attribute_identifier)}
<select name="ContentObjectAttribute_data_object_relation_id_{$:item.node_id}">
{section name=Child loop=fetch(content, list, hash( parent_node_id, $top:item.node_id ))}
<option value="{$:item.node_id}">{$:item.name|wash} ({$:item.node_id})</option>
{/section}
</select>
{/section}
{/section}

Anyone got any ideas? Going with the "Find object" button is very user unfriendly. I want them to be able to just select the fields. Help!

Thanks,
Kai

Bruce Morrison

Tuesday 05 August 2003 7:08:39 pm

Hi Kai

I've also come across this issue and looked into it in some depth.
http://ez.no/developer/ez_publish_3/forum/developer/related_objects_choosing_from_a_dropdown_instead_of_using_browse

Unfortunately it does not seem possible to achieve this with templates alone. After the related object is select from the browse window entries are made in the database to link to related object. Because of this functionality it is not possible to do this in the object edit screen.

I have been considering how to handle this. I think there are a couple of options.

1. Create a new data type "Relational Object - Select". This would allow you to nominate a node (and possibly a class id) from which the dropdown is populated. When the object is published the correct entries are created in the database.

2. Use the keywords feature to link items. Haven't looked at these yet but it may be a solution without having to code a new extension.

Cheers
Bruce
designIT

My Blog: http://www.stuffandcontent.com/
Follow me on twitter: http://twitter.com/brucemorrison
Consolidated eZ Publish Feed : http://friendfeed.com/rooms/ez-publish

Kai Duebbert

Friday 22 August 2003 3:02:27 am

Ok, found the solution. It's really simple after all and I wonder, why I didn't get it to work before. (Tried it on 3.2b1 but it also should work on 3.1)

All you have to do is change the "edit" template for the Object Relation datatype:

1. copy design/standard/templates/content/datatype/edit/ezobjectrelation.tpl to your custom design folder. Or start with an empty one.
2. The crucial line for assigning an object relation is:
<input type="hidden" name="ContentObjectAttribute_data_object_relation_id_{$attribute.data_int}" value="[CONTENTOBJECT_ID]" />

Change the "[CONTENTOBJECT_ID]" to the id of an object you want to link. E.g. I use a dropdown select box and it works like a charm.

I found it difficult to understand how the object relation actually works at first. As soon as you create a new object with object relation fields, it creates new database entries for them (have a look at contentobject_attributes and compare to the source code of the generated webpages). This is why it was hard to understand (for me).

If there is demand, then I will write a small howto in the documentation area.

Have fun,
Kai

ruud prein

Thursday 29 January 2004 2:52:45 pm

If you can find some time to write a doc about this I would be very gratefull.

regards,

Ruud

---
groet,

Ruud

Trond Åge Kvalø

Monday 23 February 2004 7:09:19 am

Hello Kai!

We're building an LMS based on eZpublish and would very much like to create relations between users and courses. In our implementation an admin user can create users and courses. Then we would like the admin user to create a "course license" with the userid and the courseid. From the little I've seen about object relations so far, I beleive that is the best option here.

Could you please provide us with an example on how to accomplish this?

Best regards
Trond Kvalo
Atlantia as
http://www.atlantia.no/

trondåge

eZ debug

Timing: Jan 18 2025 18:26:14
Script start
Timing: Jan 18 2025 18:26:14
Module start 'content'
Timing: Jan 18 2025 18:26:15
Module end 'content'
Timing: Jan 18 2025 18:26:15
Script end

Main resources:

Total runtime1.2101 sec
Peak memory usage4,096.0000 KB
Database Queries204

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0059 589.1484180.8281
Module start 'content' 0.00591.0542 769.9766639.7734
Module end 'content' 1.06010.1500 1,409.7500337.0547
Script end 1.2100  1,746.8047 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00380.3165210.0002
Check MTime0.00140.1191210.0001
Mysql Total
Database connection0.00090.072510.0009
Mysqli_queries1.127893.20362040.0055
Looping result0.00230.19412020.0000
Template Total1.181397.620.5907
Template load0.00210.172520.0010
Template processing1.179297.449120.5896
Template load and register function0.00020.015410.0002
states
state_id_array0.00110.092110.0011
state_identifier_array0.00160.132320.0008
Override
Cache load0.00170.1401570.0000
Sytem overhead
Fetch class attribute can translate value0.00190.155850.0004
Fetch class attribute name0.00170.140160.0003
XML
Image XML parsing0.00160.129250.0003
class_abstraction
Instantiating content class attribute0.00000.001660.0000
General
dbfile0.00250.2097270.0001
String conversion0.00000.001830.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
13content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
8content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 29
 Number of unique templates used: 6

Time used to render debug report: 0.0002 secs