Problem with empty option in select input

Author Message

Julien Lavergne

Tuesday 01 July 2008 4:11:12 pm

Hello,

In my project, I need to display a select list in a form. This select is required but has no default value.
To avoid the fact that ezpublish select the first item by default, in my class definition, I put an empty line option at the start of options list of my selection attribute. So my select list is well displayed with the empty line at the start.
But if I submit the form, ezpublish send value="0" instead of value="" so the value is not recognize as invalid.

So my question is : Is there a way to have a required select list with no default value (or with a null default value) without having issues with the form submit ?

Thank you

Michael Scofield

Tuesday 01 July 2008 6:28:54 pm

I'm not too experienced with Ez Publish, but I think you need to create a new datatype for that.

E.g. You can duplicate the code for existing Selection datatype, and just change or add the code specific for what you want to do. In this case, you should override the function validateCollectionAttributeHTTPInput() inside your custom datatype, and add the code for validation (if the submitted value is '0', then you return the value eZInputValidator::STATE_INVALID).

I had the same problems last week and I solved the problem creating a new datatype based on the Selection that is bundled with ez publish.

It was difficult to me to understand datatype creation because there isn't any good material on-line available explaining how to create a datatype, but I found a book (I had to pay for it) called "Learning Ez Publish", by Martin Bauer, Tony Wood, Paul Forsyt ... from Packt Publishing, and that was good enough and I could create my datatype.

You can find fragmented information in the next references - but I recommend the book above:

http://ez.no/ezpublish/documentation/development/extensions/datatypes/new_datatype

http://ez.no/developer/articles/creating_datatypes_in_ez_publish_4

Book: Ez Publish Basics, by Balazs Halasy

I hope it helps.
Michael

Julien Lavergne

Tuesday 01 July 2008 7:14:25 pm

Thank you Michael, but something tell me that it is not just a matter of new type.

In fact, as I saw in ezselection.tpl file, "selected_id_array" variable is managed as an array type variable. So the POST variable is an array, we get an array, we send an array etc... (see name="{$attribute_base}_ezselect_selected_array_{$attribute.id}[]")

But in ezselectiontype.php file, to check if the variable is valid or not, we manage this array as a string (see $data == "")

So I would say that there is a mistake in ezselectiontype.php file and that the variable has to be managed as in ezcountrytype.php (see count( $data ) > 0 and $data[0] != '').
By this way, I will be able to change just ezselection.tpl file to handle empty options like :

  {if $Options.item.name|compare("")}
    <option value="" {if $selected_id_array|count()|eq(0)}selected="selected"{/if}>{$Options.item.name|wash( xhtml )}</option>
  {else}
    <option value="{$Options.item.id}" {section show=$selected_id_array|contains( $Options.item.id )}selected="selected"{/section}>{$Options.item.name|wash( xhtml )}</option>
  {/if}

Am I totally wrong ?

<b>ezselection.tpl</b>

{* DO NOT EDIT THIS FILE! Use an override template instead. *}
{default attribute_base=ContentObjectAttribute}
{let selected_id_array=cond( is_set( $#collection_attributes[$attribute.id] ), $#collection_attributes[$attribute.id].content, $attribute.content )}

{* Always set the .._selected_array_.. variable, this circumvents the problem when nothing is selected. *}
<input type=hidden name="{$attribute_base}_ezselect_selected_array_{$attribute.id}" value="">

<select name="{$attribute_base}_ezselect_selected_array_{$attribute.id}[]" {section show=$attribute.class_content.is_multiselect}multiple{/section}>
{section var=Options loop=$attribute.class_content.options}
<option value="{$Options.item.id}" {section show=$selected_id_array|contains( $Options.item.id )}selected="selected"{/section}>{$Options.item.name|wash( xhtml )}</option>
{/section}
</select>
{/let}
{/default}

<b>ezselectiontype.php</b>

function validateCollectionAttributeHTTPInput( $http, $base, $contentObjectAttribute )
    {
        if ( $http->hasPostVariable( $base . '_ezselect_selected_array_' . $contentObjectAttribute->attribute( 'id' ) ) )
        {
            $data = $http->postVariable( $base . '_ezselect_selected_array_' . $contentObjectAttribute->attribute( 'id' ) );

            if ( $data == "" && $contentObjectAttribute->validateIsRequired() )
            {
                $contentObjectAttribute->setValidationError( ezi18n( 'kernel/classes/datatypes', 'Input required.' ) );
                return eZInputValidator::STATE_INVALID;
            }
            else
            {
                return eZInputValidator::STATE_ACCEPTED;
            }
        }
        else
        {
            return eZInputValidator::STATE_INVALID;
        }
    }

<b>ezcountrytype.php</b>

function validateCollectionAttributeHTTPInput( $http, $base, $contentObjectAttribute )
    {
        if ( !$contentObjectAttribute->validateIsRequired() )
            return eZInputValidator::STATE_ACCEPTED;

        if ( $http->hasPostVariable( $base . '_country_' . $contentObjectAttribute->attribute( 'id' ) ) )
        {
            $data = $http->postVariable( $base . '_country_' . $contentObjectAttribute->attribute( 'id' ) );

            if ( count( $data ) > 0 and $data[0] != '' )
                return eZInputValidator::STATE_ACCEPTED;
        }

        $contentObjectAttribute->setValidationError( ezi18n( 'kernel/classes/datatypes',
                                                             'Input required.' ) );
        return eZInputValidator::STATE_INVALID;
    }

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 10:55:32
Script start
Timing: Jan 18 2025 10:55:32
Module start 'layout'
Timing: Jan 18 2025 10:55:32
Module start 'content'
Timing: Jan 18 2025 10:55:33
Module end 'content'
Timing: Jan 18 2025 10:55:33
Script end

Main resources:

Total runtime0.7625 sec
Peak memory usage4,096.0000 KB
Database Queries57

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0052 588.0469152.6406
Module start 'layout' 0.00520.0031 740.687539.4766
Module start 'content' 0.00830.7525 780.1641495.8516
Module end 'content' 0.76090.0015 1,276.015616.1250
Script end 0.7624  1,292.1406 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00330.4358160.0002
Check MTime0.00140.1845160.0001
Mysql Total
Database connection0.00060.080510.0006
Mysqli_queries0.710993.2337570.0125
Looping result0.00060.0794550.0000
Template Total0.726995.320.3634
Template load0.00210.281320.0011
Template processing0.724795.051420.3624
Template load and register function0.00030.033810.0003
states
state_id_array0.00090.120010.0009
state_identifier_array0.00210.272920.0010
Override
Cache load0.00180.2350340.0001
Sytem overhead
Fetch class attribute can translate value0.00080.099720.0004
Fetch class attribute name0.00120.159830.0004
XML
Image XML parsing0.00030.033420.0001
class_abstraction
Instantiating content class attribute0.00000.001130.0000
General
dbfile0.00070.0926100.0001
String conversion0.00000.001540.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
3content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
9content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
3content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
4content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 21
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs